asp.net

位置:IT落伍者 >> asp.net >> 浏览文章

Asp.Net下通过切换CSS换皮肤


发布日期:2020年12月20日
 
Asp.Net下通过切换CSS换皮肤
换皮肤的方式有很多种最简单的通常就是切换页面CSS而CSS通常写在外部CSS文件里那么切换css其实就是更换html里的link href路径我在网上搜索了下一般有两种方式

在页面放一个holder控件然后用编程方式把当前用户的风格css link写入页面

通过反射机制逐个控件设置css样式

上面两种方式都挺麻烦的

第一种需要在每个页面上放一个holder控件类似的做法还有把link标签加runat=server的做法页面多了都比较麻烦

第二种不用考虑了性能编程效率上问题多多

记得以前在学习DNN的时候在他里面发现了一种修改form里默认的action地址的方式直接参考下还不错

直接重写Render事件

protected override void Render(SystemWebUIHtmlTextWriter writer)

{

StringWriter sw = new StringWriter() ;

HtmlTextWriter htmlWriter = new HtmlTextWriter(sw) ;

baseRender(htmlWriter) ;

//当前用户选择的风格css

string css = <link href=\css url\ rel=\stylesheet\ type=\text/css\> ;

string html = swToString() ;

int startPoint = htmlIndexOf(</head> StringComparisonCurrentCultureIgnoreCase);

if (startPoint > )

{

html = htmlInsert(startPoint css);

}

writerWrite(html) ;

}

把这个放在每个页面的基类PageBase里那就方便多了

当然如果不想在让每个page都继承自定义的基类的方式那也可以通过在HttpModule里写也很方便

一处写好页页受用呀

;

上一篇:ASP.NET 链接数据库基础教程

下一篇:ASP.Net状态管理的四种状态类型