CommunityServer读取Blog分析(一)
首選,會建立 AggregatePostList 類的一個實例,先執行 AggregatePostList 類的構造函數,并執行類中有賦初值的所有語句,因為 AggregatePostList 是繼承于 WeblogBaseTemplatedWebControl 類,而 WeblogBaseTemplatedWebControl 類又繼承于 TemplatedWebControl 類,而 TemplatedWebControl 類又繼承于 WebControl 類,且實現 INamingContainer 接口,所以,嚴格的說應該一開始是執行這四個類的構造函數(默認的構造函數,即沒有參數的構造函數)和這四個類中所有有賦初值的語句。且執行順序是從基類開始!好,第一個,WebControl的構造函數,輸出HTML元素<span id=”xxx”></span>,接下來看 TemplatedWebControl 類,該類沒有構造函數,再接著看 WeblogBaseTemplatedWebControl 類的構造函數,只有一句:
_currentUser = CSContext.Current.User;
獲取當前瀏覽者的各方面信息,詳細見 CommunityServer.Components.User 類。
最后看 AggregatePostList 類的構造函數,哈,空的,過!
在這個過程中,要注意各類中賦初值的語句,因為有一些信息不知不覺已經初始化,而在后面分析代碼卻不知是從何而來。
接下來,應該轉到 AggregatePostList 類的 OnLoad 函數,第一句:
base.OnLoad(e);
此方法通知服務器控件應執行關聯頁的每個 HTTP 請求的共同操作,例如設置數據庫查詢。在頁生存期的此階段,創建并初始化層次結構中的服務器控件,還原視圖狀態,并且窗體控件反映客戶端數據(這一段理解不是很深,不敢多寫)。下一句:
this.EnsureChildControls();
EnsureChildControls 函數是System.Web.UI.Control類的一個protected virtual void 方法(虛擬方法,提供默認實現)。代碼如下:
protected virtual void EnsureChildControls()
{
????? if (!this.ChildControlsCreated && !this.flags[0x100])
????? {
??????????? this.flags.Set(0x100);
??????????? try
??????????? {
????????????????? this.ResolveAdapter();
????????????????? if (this._adapter != null)
????????????????? {
??????????????????????? this._adapter.CreateChildControls();
????????????????? }
????????????????? else
????????????????? {
??????????????????????? this.CreateChildControls();
????????????????? }
????????????????? this.ChildControlsCreated = true;
??????????? }
??????????? finally
??????????? {
?????? ???????????this.flags.Clear(0x100);
??????????? }
????? }
}
MSDN:
功能:確定服務器控件是否包含子控件。如果不包含,則創建子控件。
該方法首先檢查 ChildControlsCreated 屬性的當前值。如果此值為假,則調用 CreateChildControls 方法。其中:
ChildControlsCreated 屬性:設置或指示是否已創建服務器控件的子控件。
CreateChildControls 方法:一個 virtual(虛擬)方法,沒提供默認實現,一般由開發復合服務器控件或模板服務器控件的用戶重寫此方法,用于創建自定義控件的子控件。WebControl 類沒有重新此方法,那么其它三個類()中必定有一個重寫此方法。確實,在 TemplatedWebControl 類就有如下的定義:
protected override void CreateChildControls()
{
Controls.Clear();
?
// 1) String Control
Boolean _skinLoaded = LoadTextBasedControl();
?
// 2) Inline Template
if ( !_skinLoaded )
{
_skinLoaded = LoadSkinTemplate();
}
?
// 3) Themed Control
if (!_skinLoaded)
{
_skinLoaded = LoadThemedControl();
}
?
// 4) Default Control
if ( !_skinLoaded )
{
_skinLoaded = LoadDefaultThemedControl();
}
?
// 5) If none of the skin locations were successful, throw.
if ( !_skinLoaded )
{
throw new CSException( CommunityServer.Components.CSExceptionType.SkinNotFound, this.GetType().ToString() );
}
?
if(_skinLoaded)
???? AttachChildControls();
}
上面說了,CreateChildControls 方法是創建自定義控件的子控件(在此是某個 Web 用戶控件)。首先,執行 Controls.Clear() 方法,從當前服務器控件的 ControlCollection 對象中移除所有控件。接著根據不同情況,調用不同的方法創建不同的控件,這些方法都以Load開頭,每個方法都被設計為虛擬(virtual)方法。首先是LoadTextBasedControl() 方法,代碼如下:
protected virtual bool LoadTextBasedControl()
{
string text = ControlText();
if(!Globals.IsNullorEmpty(text)) // text 為空或為 null 時 IsNullorEmpty 方法返回真。
{//有指定 Web 用戶控件名稱
Control skin = this.Page.ParseControl(text);
skin.ID = "_";
this.Controls.Add(skin);
return true;
}
return false;
}
首先,執行 ControlText() 方法,該方法也被設計為虛擬方法,且默認實現是返回 null,代碼如下:
protected virtual string ControlText()
{
return null;
}
為什么要這樣做呢?我認為是為了有更好的擴展性,如:我們要創建的 Web 用戶控件的名稱需要從數據庫讀取,那么就可以重寫 ControlText() 方法,然后在 ControlText() 方法中從數據庫讀出并返回控件名稱,或通過在 ControlText() 方法用其它方法返回控件名稱。在此例,LoadTextBasedControl() 方法返回 false。而一旦調用某個方法創建好子控件后,其它情況將被忽略,直至調用 AttachChildControls() 方法。好,接下來分析調用 LoadSkinTemplate() 方法的情況,當用戶控件有出現模板化屬性的情況下將會調用 LoadSkinTemplate() 方法,模板的名稱和用戶控件的類的屬性相關聯,如 TemplatedWebControl 類就以下定義:
?
public ITemplate SkinTemplate
{
get
{
return _skinTemplate;
}
set
{
_skinTemplate = value;
ChildControlsCreated = false;
}
}
private ITemplate _skinTemplate;
?
說明 SkinTemplate 就是一個模板屬性,在頁面中就可以如下引用:
<Blog:AggregatePostList runat="Server" id="Aggregatepostlist1" NAME="Aggregatepostlist1" EnablePaging="true">
<SkinTemplate>
Server control, data-binding syntax, other valid markup
</SkinTemplate>
</Blog: AggregatePostList>
?
?
?
轉載于:https://www.cnblogs.com/pcvc/archive/2006/08/11/474292.html
總結
以上是生活随笔為你收集整理的CommunityServer读取Blog分析(一)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 红黑树的删除_红黑树
- 下一篇: 试验一下……