前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Asp.Net下通过切换CSS换皮肤

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

作者头像
Java架构师必看
发布2020-10-15 10:33:41
5230
发布2020-10-15 10:33:41
举报
文章被收录于专栏:Java架构师必看

换皮肤的方式有很多种,最简单的通常就是切换页面CSS,而CSS通常写在外部CSS文件里。那么切换cs

强烈推介IDEA2020.2破解激活,IntelliJ IDEA 注册码,2020.2 IDEA 激活码

换皮肤的方式有很多种,最简单的通常就是切换页面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里写。也很方便. 一处写好,页页受用呀。

本文由来源 21aspnet,由 system_mush 整理编辑,其版权均为 21aspnet 所有,文章内容系作者个人观点,不代表 Java架构师必看 对观点赞同或支持。如需转载,请注明文章来源。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档