码迷,mamicode.com
首页 > Web开发 > 详细

ASP.NET重写Render 加载CSS样式文件和JS文件(切换CSS换皮肤)

时间:2015-11-05 00:19:58      阅读:257      评论:0      收藏:0      [点我收藏+]

标签:

网页换皮肤的方式有很多种,最简单的通常就是切换页面CSS,而CSS通常写在外部CSS文件里。那么切换CSS其实就是更换html里的link href路径。我在网上搜索了下。

一般有两种方式:

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

2、过反射机制,逐个控件设置css样式。

上面两种方式都挺麻烦的,第一种需要在每个页面上放一个holder控件,类似的做法还有把link标签加runat=server的做法,页面多了,都比较麻烦。第二种不用考虑了,性能编程效率上都问题多多。

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

直接重写Render事件

protected override void Render(System.Web.UI.HtmlTextWriter writer)
{
StringWriter sw = new StringWriter();
HtmlTextWriter htmlWriter = new HtmlTextWriter(sw);

base.Render(htmlWriter);
//当前用户选择的风格css
string css = "<link href="css url" rel="stylesheet" type="text/css">";

string html = sw.ToString() ;
int startPoint = html.IndexOf("</head>", StringComparison.CurrentCultureIgnoreCase);
if(startPoint > 0)
{
html = html.Insert(startPoint, css);
}

writer.Write(html) ;
}

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

当然,如果不想在让每个page都继承自定义的基类的方式,那也可以通过在HttpModule里写。也很方便,一处写好,页页受用呀。

ASP.NET重写Render 加载CSS样式文件和JS文件(切换CSS换皮肤)

标签:

原文地址:http://www.cnblogs.com/Alenliu/p/4937726.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!