Asp.Net2.0實現自定義樣式
我們在做一個專案時有時候需要動態改變所有頁面的樣式,但當我們在Page指令或者Web.Config裡設定Theme時有一個問題,我無法通過程式動態且一致改變所有頁面的樣式,推薦一個方法,就是改寫OnPreInit事件,在App_Code裡新建一個PageBase類,他繼承自System.Web.UI.Page,然後所有頁面再繼承自PageBase,就搞定了,具體實現就自己看吧:
using System;
using System.Data;
using System.Configuration;
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;
///
/// PageBase 的摘要說明
///
public class PageBase:System.Web.UI.Page
{
public PageBase()
{
//
// TODO: 在此處新增建構函式邏輯
//
}
protected override void OnPreInit(EventArgs e)
{
base.OnPreInit(e);
if (Request.Cookies["skin"] != null && Request.QueryString["skin"] == null)
{
Page.Theme = Request.Cookies["skin"].Value.ToString();
}
else
{
if (Request.QueryString["skin"] != null)
{
HttpCookie c = new HttpCookie("skin", Request.QueryString["skin"]);
Response.Cookies.Add(c);
Page.Theme = Request.Cookies["skin"].Value.ToString();
}
else
Page.Theme = "skin";
}
}
}
using System;
using System.Data;
using System.Configuration;
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;
///
/// PageBase 的摘要說明
///
public class PageBase:System.Web.UI.Page
{
public PageBase()
{
//
// TODO: 在此處新增建構函式邏輯
//
}
protected override void OnPreInit(EventArgs e)
{
base.OnPreInit(e);
if (Request.Cookies["skin"] != null && Request.QueryString["skin"] == null)
{
Page.Theme = Request.Cookies["skin"].Value.ToString();
}
else
{
if (Request.QueryString["skin"] != null)
{
HttpCookie c = new HttpCookie("skin", Request.QueryString["skin"]);
Response.Cookies.Add(c);
Page.Theme = Request.Cookies["skin"].Value.ToString();
}
else
Page.Theme = "skin";
}
}
}
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12639172/viewspace-442004/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- SQLserver自定義樣式主鍵-函式實現篇SQLServer函式
- 自定義Toast樣式AST
- Css實現checkbox及radio樣式自定義CSS
- 如何自定義 drag 樣式
- mui toast自定義樣式UIAST
- 自定義 checkbox 樣式
- 自定義dialog樣式
- Qt Charts 自定義樣式QT
- PHPCMS自定義表單樣式PHP
- android自定義button樣式Android
- cnBlogs的自定義樣式
- jQuery如何實現新增自定義函式jQuery函式
- Vue + WebRTC 實現音視訊直播(附自定義播放器樣式)VueWeb播放器
- CefSharp自定義捲軸樣式
- Houdini - 建立自定義的button樣式
- CSS自定義滑鼠指標樣式CSS指標
- ModernUI教程:如何從MUI樣式中派生自定義樣式UI
- 自定義View:自定義屬性(自定義按鈕實現)View
- checkbox/radio自定義樣式
- pixi.js 自定義游標樣式JS
- input[type="radio"]自定義樣式
- jQuery validate 自定義樣式、規則jQuery
- 自定義瀏覽器捲軸樣式瀏覽器
- vue原生指令v-model實現自定義樣式の多選與單選Vue
- Flex SDK 4(Gumbo)更方便的自定義樣式、自定義SparkSkin(二)薦FlexSpark
- 論如何在手機端web前端實現自定義原生控制元件的樣式Web前端控制元件
- 自定義View:畫布實現自定義View(折線圖的實現)View
- 「HTML+CSS」--自定義按鈕樣式【004】HTMLCSS
- 「HTML+CSS」--自定義按鈕樣式【003】HTMLCSS
- 自定義Toast樣式+改變Toast寬高AST
- antd-mobile 自定義picker按鈕樣式
- 自定義瀏覽器滾動條樣式瀏覽器
- 自定義checkbox樣式(相容IE9)IE9
- [HTML/CSS]uploadify自定義按鈕樣式HTMLCSS
- QFileDialog自定義樣式設定SetStytlesheet
- vxe-table 自定義單元格樣式
- Net 實現自定義Aop
- EventSource的自定義實現