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

ASP.NET
探讨:ASP.NET技术的学习顺序问题
关于ASP.NET在IIS一些问题的经验总结
ASP.NET中通过对话框方式下载文件
ASP.NET网络编程中常用到的27个函数集
ASP.NET生成静态网页的方法
ASP.NET 2.0中实现弹窗报警提示
复杂ASP.NET服务器控件调整小技巧
ASP.NET调用oracle存储过程实现快速分页
VB.NET实现窗体图标最小化到状态栏
ASP.NET技巧:DataGrid传统分页方式
ASP.NET里的事务处理
ASP.NET 2.0高级数据处理之数据绑定
ASP.NET多频道网站架构实现方法
.NET vs J2EE——面对SOA的荒谬与误解
ASP.NET 2.0中执行数据库操作命令之一
ASP.NET应用程序资源访问安全模型
ASP.NET 2.0中的Web和HTML服务器控件
对.NET Framework 反射的反思
带你走进ASP.NET(1)
带你走进ASP.NET(2)

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


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