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

ASP.NET
.Net业务平台的数值精度陷阱与解决方法
投票结果的图片进度条显示
七招制胜ASP.NET应用程序开发
ASP.NET 2.0的导航控件treeview和menu的实例
ASP.NET实现页面间值传递的几种方法
项目调试时出现用到的一个组件“访问被拒绝”的解决方法
ASP.NET中“找不到指定模块”的解决办法
C#中的委托和事件
在指定应用程序域中执行代码
Ajax简单客户登陆验证
AJAX将成为移动Web2.0时代首选开发平台
关闭按钮点击事件的捕捉
远程抓取GOOGLE的自动翻译结果
保护你的DLL和Code不被别人使用
ASP.NET的底层的工作机制介绍
ASP.NET2.0服务器控件之捕获回传事件
使用Data Access Application Block 得到存储过程的返回值
面向服务及其在互联系统策略中的角
ASP.NET2.0服务器控件之创建复杂属性
ASP.NET:设置页面buffer引出来的问题

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-13   浏览: 111 ::
收藏到网摘: 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>