一、创建主题
在名为App_Themes的应用程序的文件夹中新增文件夹就可以创建主题。在App_Themes中添加的每一个文件夹都代表一个主题。
在主题文件夹中比较重要的文件类型有皮肤文件和CSS文件。
二、在主题中添加皮肤
一个主题可能包含一个或多个皮肤文件。可以通过皮肤来修改所有具有皮肤效果的ASP.NET控件属性。
例如,将Web应用程序中所有的TextBox控件的背景颜色设为黄色并选择dotted作为它的边框样式。在App_Themes文件夹下建立Simple文件夹,然后在Simple文件夹中建立TextBox.skin文件,该文件代码如下所示:
注意上面代码里面runat是必须的,而且不能带ID属性。
主题文件夹下可以拥有一个或上百给皮肤文件,但在一个主题文件夹下的所有的文件都会编译成一个主题类。
上面的主题文件夹Simple如果要在某个页面使用其定义的主题,则使用如下代码:
如果该页面的TextBox控件属性EnableTheming设置为false,则主题不起作用。
1、 创建命名皮肤
在定义命名皮肤时比定义默认皮肤增加SkinID属性,在应用主题页面指定控件的SkinID属性为命名皮肤定义的SkinID属性名称即可。
2、 Themes和StyleSheetThems
使用Themes指定应用某个主题时候,主题定义皮肤会覆盖页面中控件自定义的皮肤。
而使用StyleSheetThems指定则不会覆盖。
3、 禁用皮肤
每个控件都包含有EnableTheming属性,设置为false则禁用主题皮肤。
4、 在Web配置文件中注册主题
在启用程序中的主题后,可以在特定页面中通过
来禁用主题。
三、在主题中添加CSS
除了使用主题皮肤外,也可以使用CSS来控制页面上HTML元素和ASP.NET控件的皮肤。如果在主题文件夹下添加了CSS文件,则在页面应用主题时也会自动应用CSS。
四、创建全局主题
此种情况本人应用较少,跳过。对于很少用到的知识而且又不是基础性的,我的学习原则是知道有这个应用即可,待有机会真正用上时再学习也不迟。不然在技术的汪洋大海里面永远也不知岸在哪里。
五、动态应用皮肤
通过处理页面的Page_PreInit事件可以在页面动态应用主题。在请求页面时,这是第一个被触发的事件。在其后的Page_Load或Page_PreRender等事件中是不能动态应用主题的。
protected void Page_PreInit(object sender, EventArgs e)
{
if (Request["theme"] != null)
{
switch (Request["theme"])
{
case "Green":
Profile.userTheme = "GreenTheme";
break;
case "Pink":
Profile.userTheme = "PinkTheme";
break;
}
}
Theme = Profile.userTheme;
}
Dynamic Theme
通过页面的Theme属性,特定主题可以应用到此页面。通过在PreInit事件中将主题名称赋给Theme属性,主题将会应用到此页面。
当把信息保存到Profile对象中时,在浏览多个站点时这个信息仍然会保留。所以如果用户选择了一次自己喜欢的主题,那么当用户在以后再次返回到此站点时仍然会应用此主题。
在Web.Config文件中定义Profile
<!--
-->
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/12639172/viewspace-594854/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/12639172/viewspace-594854/