asp.net2.0揭秘读书笔记三:使用主题设计网站

一、创建主题

在名为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、 ThemesStyleSheetThems

使用Themes指定应用某个主题时候,主题定义皮肤会覆盖页面中控件自定义的皮肤。

而使用StyleSheetThems指定则不会覆盖。

3、 禁用皮肤

每个控件都包含有EnableTheming属性,设置为false则禁用主题皮肤。

4、 Web配置文件中注册主题

在启用程序中的主题后,可以在特定页面中通过

来禁用主题。

 

三、在主题中添加CSS

除了使用主题皮肤外,也可以使用CSS来控制页面上HTML元素和ASP.NET控件的皮肤。如果在主题文件夹下添加了CSS文件,则在页面应用主题时也会自动应用CSS

 

四、创建全局主题

此种情况本人应用较少,跳过。对于很少用到的知识而且又不是基础性的,我的学习原则是知道有这个应用即可,待有机会真正用上时再学习也不迟。不然在技术的汪洋大海里面永远也不知岸在哪里。

 

五、动态应用皮肤

通过处理页面的Page_PreInit事件可以在页面动态应用主题。在请求页面时,这是第一个被触发的事件。在其后的Page_LoadPage_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

   

   

   

   

Dynamic Theme

 

    Please select a Theme:

   

   

        Green Theme

   

   

        Pink Theme

    

   

   

   

   

 

通过页面的Theme属性,特定主题可以应用到此页面。通过在PreInit事件中将主题名称赋给Theme属性,主题将会应用到此页面。

当把信息保存到Profile对象中时,在浏览多个站点时这个信息仍然会保留。所以如果用户选择了一次自己喜欢的主题,那么当用户在以后再次返回到此站点时仍然会应用此主题。

Web.Config文件中定义Profile

 

    <!--

   

    --&gt

 

   

     

       

     

   

   

 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/12639172/viewspace-594854/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/12639172/viewspace-594854/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值