下面图老师小编跟大家分享Asp.Net下通过切换CSS换皮肤,一起来学习下过程究竟如何进行吧!喜欢就赶紧收藏起来哦~
【 tulaoshi.com - Web开发 】
换皮肤的方式有很多种,最简单的通常就是切换页面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里写。也很方便.
  一处写好,页页受用呀。
http://www.cnblogs.com/kwklover/archive/2007/01/03/610822.html
来源:http://www.tulaoshi.com/n/20160219/1627255.html
看过《Asp.Net下通过切换CSS换皮肤》的人还看了以下文章 更多>>