stylesheettheme和 theme
stylesheettheme和 theme属性可以同时应用,起应用方法基本都是一样的,只是执行的优先级不同
1.如果页面单独使用stylesheettheme属性指定主题,那么内容页内定义的控件属性将覆盖sylesheettheme定义的控件属性
2. 如果页面单独使用theme属性,那么只执行theme属性所定义的主题,内容页内定义的属性将不起作用!
3. 如果页面内同时定义stylesheettheme和theme属性指定主题,
那么优先级从低到高是 stylesheettheme>> 内容页内定义的属性>>然后才是theme
4.如果定义了skin文件,若是指定Theme,则skin属性将覆盖页面控件相应属性,而指定StyleTheme则不会。
注意:
1、如果主题是通过设置 @Page 指令或配置的 <pages/> 节的Theme 属性 (attribute) 应用的,则主题中的外观属性 (property) 将重写页中目标控件的同名属性(property)。
2、通过将 @Page 指令或配置的 <pages/> 节的StyleSheetTheme 属性设置为主题的名称,可以将主题定义作为服务器端样式来应用。
主题属性用作 StyleSheetTheme 时,可能被页中的控件重写。
3、 StyleSheetTheme应在应用程序开发过程中应用,它作为从页中提取样式信息的手段,使应用程序的行为可独立于应用程序的外观进行维护。
对应用程序应用 StyleSheetTheme 后,您可能还希望应用Theme。如果对应用程序既应用 Theme 又应用 StyleSheetTheme,则按以下顺序应用控件的属性:
首先应用 StyleSheetTheme 属性
应用页中的控件属性(重写 StyleSheetTheme)
最后应用 Theme 属性(重写控件属性和 StyleSheetTheme)
4、在皮肤文件里面可以针对同一个控件设置多个皮肤风格,使用skinid来区分不同风格,并在aspx页面文件的控件中使用skinid来引用不同皮肤风格。
5.以编程方式应用页面主题
在页面的 PreInit方法的处理程序中,设置页面的 Theme属性。
下面的代码示例演示如何根据查询字符串中传递的值按条件设置页面主题。
为应用程序指定和禁用主题
Protected void Page_PreInit(object sender, EventArgs e)
{
switch(Request.QueryString["theme"])
{
case "Blue":
<b>Page.Theme= "BlueTheme";</b>
break;
case "Pink":
<b>Page.Theme= "PinkTheme";</b>
break;
}
}
6.将 @ Page 指令的 EnableTheming 属性设置为 false,
<%@ Page EnableTheming="false" %>
7.对网站应用主题
每个应用程序中都包括多个页面,并且为了保证和谐统一的用户界面,我们可以让所有页面使用同一主题。
如果为在每个页头都设置相同的Theme属性值,那么非常麻烦。
为了快速地为整个应用程序的所有页面设置相同的主题,可以设置Web.Config文件的<pages>配置节内容。
<configuration><system.web> <pagestheme="sampleTheme" /></system.web></configuration>