当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > ASP.NET通过使页面动态加载不同CSS实现多界面

ASP.NET
ASP.NET立即上手教程(13)
ASP.NET立即上手教程(14)
Repeater控件分页例子
从文本文件读取行信息
Asp.Net 2.0数据库基本操作方法学习
url传递中文的解决方案
如何实现无刷新的DropdownList联动效果
将非模态对话框显示为模态对话框
微软新版开发工具VS 2008 beta2功能定案
c#.net函数列表
.Net FW中无法正确显示中文问题
ASP.NET中的doPostBack脚本函数实例
教你在asp.net中动态变更CSS
一个功能齐全的DataGrid分页例子
在ASP.NET程序中创建唯一序号
asp.net 2.0中用GRIDVIEW插入新记录
ASP.Net中保护自定义的服务器控件
在ASP.NET中跨页面实现多选
转换DataSet到普通xml的新法
ASP.NET中用healthMonitor属性用法

ASP.NET通过使页面动态加载不同CSS实现多界面


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-13   浏览: 108 ::
收藏到网摘: n/a

  ASP.Net中利用CSS实现多界面两种方法。

  方法一:

<%@page language="C#"%>  
<%@import namespace="System.Data"%>  
<script language="c#" runat="server">  
public void page_load(Object obj,EventArgs e)  
{  
//创建服务器端控件.  
//指定的标记"LINK"初始化此类的新实例.  
HtmlGenericControl objLink=new HtmlGenericControl("LINK");  
objLink.ID=ID;  
objLink.Attributes["rel"]="stylesheet";  
objLink.Attributes["type"]="text/css";  
objLink.Attributes["href"]="portal.css";  
//此控件不产生任何可见输出,仅作为其他控件的容器,可在其中添加,插入或移除控件.  
MyCSS.Controls.Add(objLink);  
}  
</script>  
<html>  
<head>  
<title>c#</title>  
<asp:placeholder id="MyCSS" runat="server"></asp:placeholder>  
</head>  
<body bgColor="#ffcc66" style="FONT:9pt">  
<form runat="server">  
</form>  
</body>  
</html>  

  通过动态设置页面所有同类型控件的样式来变界面:

  方法二:

  可以通过改变WEB控件的CssClass属性,可方便地设置和修改控件的样式。但在实际开发过程中,一个个地设置控件的CssClass属性,非常繁琐,所以此思路应用不广.

  但下面的代码段演示了一次性改变页面所有同类型控件的样式的方法,可以实现简单的SKIN等功能。

  代码如下:

public void page_load(Object obj,EventArgs e)  
{  
if(!Page.IsPostBack){  
//为页面的所有控件设置样式.  
SetCSS(Page.Controls);  
}  
}  
private void SetCSS(System.Web.UI.ControlCollection vControls)  
{  
for(int i=0;i<vControls.Count;i++)  
{  
System.Web.UI.Control vControl=vControls[i];  
//得到控件的类型  
//可增加控件类型及相应处理方法  
string PType=vControl.GetType().Name;  
switch (PType)  
{  
case "TextBox":  
TextBox_CSS ((TextBox) vControl);  
break;  
case "Button":  
//Button_CSS ((Button) vControl);  
break;  
case "DataGrid":  
//DataGrid_CSS ((DataGrid) vControl);  
break;  
}  
if(vControl.Controls.Count>0)  
SetCSS(vControl.Controls);  
}  
}  
private void TextBox_CSS(TextBox tb){  
tb.CssClass="TextBox_show";  
}  
<form runat="server">  
<asp:textbox id="Search1" runat="server"/>  
<asp:textbox id="Search2" CssClass="INPUT" runat="server"/>  
</form>