博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ASP.NET 主题(Themes)FAQ
阅读量:6507 次
发布时间:2019-06-24

本文共 2201 字,大约阅读时间需要 7 分钟。

1、
主题是什么
   主题由一组元素组成:外观、级联样式表 (CSS)、图像和其他资源。主题将至少包含外观。主题是在网站或 Web 服务器上的特殊目录中定义的。主题是一组Web Control的属性设置的集合,提供一种简单的方法设置控件的样式属性。
·         
主题只在
Web Control中有效
·         
母板页(
Master Page)上不能设置主题,但是主题可以在内容页面上设置
·         
主题上设置的
Web Control的样式覆盖页面上设置的样式
·         
如果在页面上设置
EnableTheming
="false"
主题无效
·         
要在页面中动态设置主题,必须在页面生命周期
Page_Preinit
事件之前
·         
主题包括
.skin
.css
文件
2、
.skin
是什么文件
.skin是外观文件,它包含各个控件(例如,ButtonLabelTextBox  Calendar 控件)的属性设置。控件外观设置类似于控件标记本身,但只包含您要作为主题的一部分来设置的属性。例如,下面是 Button 控件的控件外观:
<asp:button runat="server" BackColor="lightblue" ForeColor="black" />
 theme 文件夹中创建 .skin 文件。一个 .skin 文件可以包含一个或多个控件类型的一个或多个控件外观。可以为每个控件在单独的文件中定义外观,也可以在一个文件中定义所有主题的外观。有两种类型的控件外观 -“默认外观”和“已命名外观”:
·         
当向页应用主题时,默认外观自动应用于同一类型的所有控件。如果控件外观没有
 SkinID 属性,则是默认外观。例如,如果为 Calendar 控件创建一个默认外观,则该控件外观适用于使用本主题的页面上的所有 Calendar 控件。(默认外观严格按控件类型来匹配,因此 Button 控件外观适用于所有 Button 控件,但不适用于 LinkButton 控件或从 Button 对象派生的控件。)
·         
已命名外观是设置了
 SkinID 属性的控件外观。已命名外观不会自动按类型应用于控件。而应当通过设置控件的 SkinID 属性将已命名外观显式应用于控件。通过创建已命名外观,可以为应用程序中同一控件的不同实例设置不同的外观。
3、
如何为相同控件定义不同的Skin
    使用SkinID为控件定义不同的skin,例如
<asp:Label runat=server Text="ThemedLabel" BackColor="Red" /> -label的缺省外观          <asp:Label runat=server SkinId="BoldLabel" Text="ThemedLabel_WithSkinId" BackColor="Blue" Font-Bold="true" /> - 命名为BoldLabel Label外观
   因此页面没有指定SkinIdlabel自动应用缺省外观,LabelSkinID设置为BoldLabelLabel控件应用BoldLabel外观
4、
如何组织主题文件内容
   Theme文件下可以包含多个.Skin文件,所以可以多种方式组织你的主题文件,所有的主题文件在应用于页面之前会合并。
·         
一个
.skin文件包含所有的控件的外观定义
·         
每个控件一个
.skin文件
·         
相同
SkinID的控件放在一个.skin文件中
5、
有没有办法定义好的Theme
文件在多个程序中共享
服务器上的任何网站以及任何网站中的任何页面都可以引用全局主题,使用全局的主题可以在各个应用程序之间共享,例如你想创建一个全局共享的主题
theme1IIS 服务器上的全局主题放置位置类似于 \Inetpub\wwwroot\aspnet_client\system_web\v2.0.xxxxx\Themes\Theme1
应用程序级别的主题会覆盖全局的主题,例如你在应用程序中也定义了
Theme1的主题,那么在应用程序级的Theme1主题将覆盖全局的主题Theme1
 
6、StyleSheetTheme
是什么
   主题还可以包含级联样式表(.css 文件)。将 .css 文件放在主题目录中时,样式表自动作为主题的一部分应用。使用文件扩展名 .css 在主题文件夹中定义样式表。设置页面的 StyleSheetTheme 属性将主题作为样式表主题来应用。如果您希望能够设置页面上的各个控件的属性,同时仍然对整体外观应用主题,则可以将主题作为样式表主题来应用。EnableTheming="false"情况下StyleSheetTheme仍然有效。通过重写属性StyleSheetTheme来动态修改页面上的主题样式
 public override string StyleSheetTheme
 {

    get{ retrun "MyStyleSheetTheme"; } 
 }
7、
主题(
Theme/Skin
)资源
一组相当不错的
Theme
,可以直接应用的项目开发中
    Theme预览:
    Theme下载:
本文转自 张善友 51CTO博客,原文链接:http://blog.51cto.com/shanyou/74943,如需转载请自行联系原作者
你可能感兴趣的文章
程序猿知道英语词汇
查看>>
数据存储(两)--SAX发动机XML记忆(附Demo)
查看>>
ECSHOP添加购物车加图片飞入效果
查看>>
谈谈SQL 语句的优化技术
查看>>
Nova 操作汇总(限 libvirt 虚机) [Nova Operations Summary]
查看>>
数据结构Java实现04----循环链表、仿真链表
查看>>
ecshop如何判断缓存文件是否能更新
查看>>
打印xls注意事项
查看>>
Linq左关联 右关联 内关联
查看>>
电脑知识--实用文章
查看>>
Android新建项目 默认布局改为 LinearLayout
查看>>
SQL Server 事务处理 回滚事务
查看>>
android usb挂载分析---MountService启动
查看>>
ZH奶酪:PHP的cURL库
查看>>
【 D3.js 入门系列 --- 3 】 做一个简单的图表!
查看>>
mybatis0208 缓存
查看>>
svn回退到具体的版本
查看>>
全栈JavaScript路(八)得知 CDATASection 种类 节点
查看>>
JSP模板文本
查看>>
javascript于boolean类型转换,运营商&amp;&amp;和|| 返回值
查看>>