当前位置: 首页 > news >正文

ASP.NET 2.0(C#) - Themes(主题)

原文链接: http://www.netfocus.cn/article1648.html

作者: webabcd


介绍
使用 ASP.NET 2.0 的“主题”功能,可以将样式和布局信息分解为单独的文件组,统称为“主题”。然后,主题可应用于任何站点,影响站点中页和控件的外观。这样,通过更改主题即可轻松地维护对站点的样式更改,而无需对站点各页进行编辑。还可与其他开发人员共享主题。


关键
1、在web site中添加App_Themes文件夹,可以在每个主题文件加内添加.skin文件、.css文件(指定主题后会自动加载主题下所有.css文件)或者图片文件

2、在web.config的<system.web>元素下的<pages>元素下设置theme或者styleSheetTheme属性(针对全局);在页的@Page指令里设置Theme或者StylesheetTheme属性(针对当前页)

3、Theme定义的样式不可以覆盖;StylesheetTheme定义的样式可以覆盖

4、.skin文件里不设置SkinId则就是默认的,设置了SkinId后则对应控件的SkinId属性

5、动态修改Page的Theme要在Page_PreInit方法中实现


示例
Blue主题
< asp:Label  runat ="server"  BackColor ="blue"  ForeColor ="white"   />
< asp:Label  runat ="server"  BackColor ="DarkBlue"  ForeColor ="white"  SkinId ="Dark"   />

<% --ImageUrl如下设置则解析到该主题下的Images文件夹的pic.jpg文件-- %>
< asp:Image  runat ="server"  ImageUrl ="Images/pic.jpg"   />

Red主题
< asp:Label  runat ="server"  BackColor ="red"  ForeColor ="white"   />
< asp:Label  runat ="server"  BackColor ="DarkRed"  ForeColor ="white"  SkinId ="Dark"   />

<% --ImageUrl如下设置则解析到该主题下的Images文件夹的pic.jpg文件-- %>
< asp:Image  runat ="server"  ImageUrl ="Images/pic.jpg"   />

主题测试-Theme
Themes/Theme.aspx
<% @ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="Theme.aspx.cs"
    Inherits
="Themes_Theme" Title="主题测试-Theme" Theme="Blue" 
%>

< asp:Content  ID ="Content1"  ContentPlaceHolderID ="ContentPlaceHolder1"  runat ="Server" >
    
< p >
        在页头部分指定Theme="Blue"
</ p >
    
< p >
        相关主题文件,我觉得最好把样式写在css里然后设置控件的CssClass属性
        
< br  />
        
&lt; asp:Label ID="Label1" runat="server" BackColor="blue" ForeColor="white" / &gt;
        
< br  />
        
&lt; asp:Label ID="Label2" runat="server" BackColor="DarkBlue" ForeColor="white"
        SkinId="Dark" /
&gt;
    
</ p >
    
< p >
        
< asp:Label  ID ="lbl"  runat ="Server"  Text ="不做任何设置(使用主题中的没设置SkinId的样式)"   />
    
</ p >
    
< p >
        
< asp:Label  ID ="lbl2"  runat ="Server"  Text ="设置BackColor为black(因为设置的是页的Theme属性,所以无法覆盖原有样式)"  BackColor ="black"   />
    
</ p >
    
< p >
        
< asp:Label  ID ="lbl3"  runat ="Server"  Text ="主题测试设置SkinID为dark(指定SkinId)"  SkinID ="dark"   />
    
</ p >
</ asp:Content >

主题测试-StylesheetTheme
Themes/StylesheetTheme.aspx
<% @ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="StylesheetTheme.aspx.cs"
    Inherits
="Themes_StylesheetTheme" Title="主题测试-StylesheetTheme" StylesheetTheme="Red" 
%>

< asp:Content  ID ="Content1"  ContentPlaceHolderID ="ContentPlaceHolder1"  runat ="Server" >
    
< p >
        在页头部分指定StylesheetTheme="Red"
</ p >
    
< p >
        相关主题文件,我觉得最好把样式写在css里然后设置控件的CssClass属性
        
< br  />
        
&lt; asp:Label ID="Label1" runat="server" BackColor="red" ForeColor="white" / &gt;
        
< br  />
        
&lt; asp:Label ID="Label2" runat="server" BackColor="DarkRed" ForeColor="white" SkinId="Dark"
        /
&gt;
    
</ p >
    
< p >
        
< asp:Label  ID ="lbl"  runat ="Server"  Text ="不做任何设置(使用主题中的没设置SkinId的样式)"   />
    
</ p >
    
< p >
        
< asp:Label  ID ="lbl2"  runat ="Server"  Text ="设置BackColor为black(因为设置的是页的StylesheetTheme属性,所以无法覆盖原有样式)"  BackColor ="black"   />
    
</ p >
    
< p >
        
< asp:Label  ID ="lbl3"  runat ="Server"  Text ="主题测试设置SkinID为dark(指定SkinId)"  SkinID ="dark"   />
    
</ p >
</ asp:Content >

主题测试-动态加载主题
Themes/Dynamic.aspx
<% @ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="Dynamic.aspx.cs"
    Inherits
="Themes_Dynamic" Title="主题测试-动态加载主题" 
%>

< asp:Content  ID ="Content1"  ContentPlaceHolderID ="ContentPlaceHolder1"  runat ="Server" >
    
< p >
        相关.skin文件内容如下:
&lt; asp:Image runat="server" ImageUrl="Images/pic.jpg" / &gt;
    
</ p >
    
< p >
        
< href ="?theme=blue" > 蓝色主题 </ a >   &nbsp; < href ="?theme=red" > 红色主题 </ a >
    
</ p >
    
< p >
        该Image控件应用主题中的样式,包括ImageUrl
        
< br  />
        
< asp:Image  ID ="img"  runat ="server"   />
    
</ p >
</ asp:Content >

Themes/Dynamic.aspx.cs
using  System;
using  System.Data;
using  System.Configuration;
using  System.Collections;
using  System.Web;
using  System.Web.Security;
using  System.Web.UI;
using  System.Web.UI.WebControls;
using  System.Web.UI.WebControls.WebParts;
using  System.Web.UI.HtmlControls;

public  partial  class  Themes_Dynamic : System.Web.UI.Page
{
    
protected void Page_Load(object sender, EventArgs e)
    
{

    }


    
protected void Page_PreInit(object sender, System.EventArgs e)
    
{
        
// 动态修改Page的Theme要在Page_PreInit方法中实现
        if (!String.IsNullOrEmpty(Request.QueryString["theme"]))
        
{
            Page.Theme 
= Request.QueryString["theme"];
        }

        
else
        
{
            Page.Theme 
= "blue";
        }

    }

}



OK
[源码下载]

相关文章:

  • 书法家
  • 我的第一份工作
  • 如何定制列表项编辑页面
  • Linux Iptables上中文man文档的详细介绍
  • 旅游经济学1
  • SMART原则的误区
  • 游戏式管理未来的管理方式
  • 第一帖~纪念~
  • 妻子-情人-红颜知己
  • 成功不是忽悠
  • 在SharePoint Designer 2007中使用交叉列表查询的数据视图
  • ASP调用WEBSERVICE(转)
  • 网络银行的插件
  • 中兴3206交换机配置
  • MySQL动态行转列
  • 2018一半小结一波
  • CentOS7简单部署NFS
  • const let
  • egg(89)--egg之redis的发布和订阅
  • extjs4学习之配置
  • FineReport中如何实现自动滚屏效果
  • HomeBrew常规使用教程
  • Laravel Mix运行时关于es2015报错解决方案
  • leetcode388. Longest Absolute File Path
  • npx命令介绍
  • SpringBoot 实战 (三) | 配置文件详解
  • 开发基于以太坊智能合约的DApp
  • 实现简单的正则表达式引擎
  • 体验javascript之美-第五课 匿名函数自执行和闭包是一回事儿吗?
  • 微信支付JSAPI,实测!终极方案
  • 在weex里面使用chart图表
  • 分布式关系型数据库服务 DRDS 支持显示的 Prepare 及逻辑库锁功能等多项能力 ...
  • ​​​​​​​ubuntu16.04 fastreid训练过程
  • ​创新驱动,边缘计算领袖:亚马逊云科技海外服务器服务再进化
  • ​油烟净化器电源安全,保障健康餐饮生活
  • #、%和$符号在OGNL表达式中经常出现
  • (01)ORB-SLAM2源码无死角解析-(56) 闭环线程→计算Sim3:理论推导(1)求解s,t
  • (2)nginx 安装、启停
  • (9)STL算法之逆转旋转
  • (DenseNet)Densely Connected Convolutional Networks--Gao Huang
  • (阿里巴巴 dubbo,有数据库,可执行 )dubbo zookeeper spring demo
  • (八)Docker网络跨主机通讯vxlan和vlan
  • (第二周)效能测试
  • (翻译)Quartz官方教程——第一课:Quartz入门
  • (附源码)计算机毕业设计SSM基于java的云顶博客系统
  • (译) 理解 Elixir 中的宏 Macro, 第四部分:深入化
  • (原創) 博客園正式支援VHDL語法著色功能 (SOC) (VHDL)
  • (转)ABI是什么
  • (转)大道至简,职场上做人做事做管理
  • **PHP分步表单提交思路(分页表单提交)
  • .bat批处理(八):各种形式的变量%0、%i、%%i、var、%var%、!var!的含义和区别
  • .bat批处理(六):替换字符串中匹配的子串
  • .gitignore
  • .NET Micro Framework初体验(二)
  • .net 按比例显示图片的缩略图