3 狀態管理和Style類
3.3 開發自定義的Style類
在上一節中,我們講到了Style類的屬性和方法。但是Style類本身並沒有提供全面的CSS 樣式屬性的支持。我們需要繼承Style類或Style類的子類,才能支持我們想要的CSS樣式屬性 。
首先我們分析我們現在所寫的Register控件的主要布局格式即Table布局,那麼我們只需 要繼承與Style類的子類TableStyle類就可以獲取Table的樣式控制。
首先我們先來添加一個新類,類名為:RegisterControleStyle。首先為 RegisterControleStyle類提供無參構造函數RegisterControleStyle()。然後在提供以下代 碼中的構造函數:
using System;
using System.Collections.Generic;
using System.Text;
using System.ComponentModel;
using System.Text;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace RegisterControl
{
public enum BackImageRepeat
{
Repeat,RepeatX,RepeatY,NoRepeat,Inherit
}
public class RegisterControlStyle : TableStyle
{
public RegisterControlStyle()
{ }
public RegisterControlStyle(StateBag viewState)
: base(viewState)
{
}
}
}
注意:在這裡的第二個構造函數傳遞了一個StateBag類型的參數,並調用了基類的構造函 數。
我們仔細觀察RegisterControleStyle類的構造函數的第二種重載形式,我們將實例化 RegisterControleStyle對象是傳遞的ViewState傳給了父類。為什麼要這麼做??聰明的園 友一定知道了,呵呵 讓父類的樣式屬性也保存在當前自定義控件的ViewState中。
在自定義控件中,還需要公開一些當前自定義控件的特定屬性,本例中我們定義一個背景 圖片重復的枚舉:
public enum BackImageRepeat
{
Repeat,RepeatX,RepeatY,NoRepeat,Inherit
}