您好,登錄后才能下訂單哦!
這篇文章主要介紹“ASP.NET中的三個基類是什么”,在日常操作中,相信很多人在ASP.NET中的三個基類是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”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); }
到此,關于“ASP.NET中的三個基類是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。