ASP.NET中的三個基類
一般我們撰寫ASP.NET控件都是繼承Framework 已有三個ASP.NET基類,Control,WebControl,CompositeControl,它們之間的關系大家都很清楚。
下面我就各個ASP.NET基類的呈現方法作一些簡單的說明:
Control,主要有以下4個方法用于呈現:
- protected internal virtual void Render
- (HtmlTextWriter writer)
- {
- this.RenderChildren();
- }
- protected internal virtual void
- RenderChildren(HtmlTextWriter writer)
- {
- //呈現子控件
- }
- public virtual void RenderControl
- (HtmlTextWriter writer)
- {
- //該方法為入口方法
- this.RenderControl(writer,this.xxxAdapter);
- }
- protected void RenderControl(HtmlTextWriter
- writer, ControlAdapter adapter)
- {
- if (adapter != null)
- {
- //調用相關的適配器方法
- }
- else
- {
- this.Render(writer);
- }
- } 整個呈現順序就是:
- 1.RenderControl(HtmlTextWriter writer)
- 2.RenderControl(HtmlTextWriter writer,
- ControlAdapter adapter)
- 3.Render(HtmlTextWriter writer)
- 4.RenderChildren(HtmlTextWriter writer)
概念上理解就是:
1.控件開始呈現
2.控件是否有相關的呈現適配器,有的話就適配器調用適配器的相關呈現方法
3.呈現子控件
4.完成控件呈現
題外話:關于控件適配器我基本上沒用過,不過可以學習這個手法,怎么樣在一個類中添加新功能而不影響原代碼,既OO的基本設計原則之一 優先使用組合。
WebControl:在Control的基礎上增加了Style,呈現方面就是在Render(HtmlTextWriter writer) 方法中擴展了三個呈現方法,增加一個屬性呈現方法, 偽代碼如下:
- publicvirtualvoidRenderBeginTag
- (HtmlTextWriterwriter)
- {
- this.AddAttributesToRender(writer);
- //呈現Tag開始標記
- }
- protectedoverridevoidRender(HtmlTextWriterwriter)
- {
- //重寫了Control的Render方法并增加了三個擴展方法
- this.RenderBeginTag(writer);
- this.RenderContents(writer);
- this.RenderEndTag(writer);
- }
- protectedinternalvirtualvoidRenderContents
- (HtmlTextWriterwriter)
- {
- //調用Control的呈現
- base.Render(writer);
- }
- publicvirtualvoidRenderEndTag(HtmlTextWriterwriter)
- {
- //呈現結束標記
- }
- protectedvirtualvoidAddAttributesToRender
- (HtmlTextWriterwriter)
- {
- //呈現Attribute
- }
- CompositeControl重寫了WebControl的Render
- (HtmlTextWriterwriter),
- 增加了設計時支持以創建子控件
- protectedinternaloverridevoidRender(HtmlTextWriterwriter)
- {
- //如果在設計時,創建子控件,也就是在設計時增加友好體驗
- if(DesignMode)
- this.EnsureChildControls();
- base.Render(writer);
- }
【編輯推薦】