ASP.NET中RenderContents控件的作用是什么

本篇文章为大家展示了ASP.NET中RenderContents控件的作用是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

创新互联建站是一家集网站建设,苍梧企业网站建设,苍梧品牌网站建设,网站定制,苍梧网站建设报价,网络营销,网络优化,苍梧网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。

基础知识

就ASP.NET服务器控件而言只存在两种情况:一种是具有外观可视化元素的控件,还有一种是不具有外观可视化元素的控件。如果需要开发的服务器控件包含可视化元素,那么多数情况下,建议开发人员创建继承自System.Web.UI.WebControls.WebControl基类的控件类。这种做法的主要原因是基于便捷性考虑。因为,WebControl类可提供服务器控件的部分与外观有关的公共属性、方法和事件等。通过该类定义的属性,可以控制服务器控件的外观和行为。例如,使用BackColor和ForeColor属性,可以分别控制服务器控件的背景色和前景颜色;在可以显示边框的控件上,可以通过设置BorderWidth、BorderStyle和BorderColor属性,控制边框宽度、边框样式和边框颜色;服务器控件的大小可以通过Height和Width属性来指定等等。如果控件基类是Control类,那么实现这些类似内容则非常繁琐。

在使用WebControl基类实现ASP.NET服务器控件呈现的过程中,必然要使用该类所提供的属性和方法等成员对象。这是读者需要重点掌握的内容。另外,对于该基类的构造函数也是不容忽视的。下面首先从WebControl的构造函数开始入手进行讲解,随后将说明常见的成员对象。

WebControl类包括三个构造函数,它们都用于初始化WebControl类的新实例,然而它们之间还存在一些细小的差异。

◆protected WebControl ()

该构造函数用于初始化表示Span HTML元素的WebControl类的新实例。通常情况下,开发人员并不直接调用此构造函数。相反,它通常由派生类的构造函数调用以将TagKey属性初始化为Span枚举值。在随后的示例中,将重写TagKey属性,从而调用此构造函数。

◆public WebControl (HtmlTextWriterTag tag)

开发人员可使用此构造函数创建并初始化使用指定的System.Web.UI.HtmlTextWriterTag值的WebControl类的新实例。其中的参数tag表示HtmlTextWriterTag枚举值之一。可能读者对于HtmlTextWriterTag还不太熟悉。它是一个枚举类型,其枚举值多为HTML标记,例如,A、B、Bold、Button等等。

◆protected WebControl (string tag)

使用此构造函数可创建并初始化使用指定的HTML标记的WebControl类的新实例。其中参数tag表示HTML标记。当使用该构造函数时一定要注意:不能直接调用此构造函数。相反,它通常由派生类的构造函数调用以初始化TagKey和TagName属性。

在了解了WebControl类的构造函数之后,读者还必须了解WebControl类的一些常用属性和方法。下面列举了这些常用成员对象,它们对于实现ASP.NET服务器控件呈现有着重要意义。

(1)Attributes属性

该属性用于获取与控件的属性不对应的任意特性(只用于呈现)的集合,其属性类型为AttributeCollection。

(2)ControlStyle属性

该属性用于获取服务器控件的样式,它是Style类型。ControlStyle属性封装WebControl类的所有外观属性,如BorderColor和Font。

(3)TagKey属性

该属性用于获取与此服务器控件相对应的System.Web.UI.HtmlTextWriterTag值,其属性类型为HtmlTextWriterTag枚举。

(4)protected virtual void AddAttributeToRender(HtmlTextWriter writer);

该方法将需要呈现的HTML属性和样式添加到指定的System.Web.UI.HtmlTextWriter中。注意在重写过程中,一定要调用基类中相应的方法。

(5)public void ApplyStyle(Style s);

该方法将指定样式的所有非空白元素复制到控件,改写控件的所有现有的样式元素。

(6)public void MergeStyle(Style s);

该方法将指定样式的所有非空白元素复制到控件,但不改写该控件现有的任何样式元素。

(7)protected override void Render(HtmlTextWriter writer);方法

该方法重写了Control.Render。

(8)protected virtual void RenderContents(HtmlTextWriter writer);

该方法将ASP.NET服务器控件的内容呈现到指定的编写器中。如果要在控件的标签中写入文本或其他内容,则需要重写该方法;如果要使用默认逻辑来呈现子控件,那么一定要调用基类中相应的方法。

可能读者已经注意到WebControl基类中包括的两个方法:Render和RenderContents。根据上文所介绍的内容可知,Control基类中包括Render方法。由于WebControl类继承自Control类,因此,WebControl类中包含Render方法是无可非议的。然而,WebControl类中却有一个RenderContents方法,并且该方法与Render方法在功能、参数等方面都非常相似。那么在呈现控件过程中到底应该使用哪一个呢?

实际上,在通常情况下,如果服务器控件自WebControl基类派生,那么其中的Render方法很少使用,而主要使用RenderContents方法实现控件呈现。为了说明其中的原因,我们必须了解WebControl基类中Render方法的实现逻辑。

在WebControl基类中的Render方法的实现示意性代码如下所示:

protected override void Render(HtmlTextWriter output)  {   RenderBeginTag(output);   RenderContents(output);   RenderEndTag(output);  }

在WebControl基类中的RenderBeginTag方法的实现示意性代码如下:

public virtual void RenderBeginTag(HtmlTextWriter output)  {   AddAttributesToRender(output);    HtmlTextWriterTag tagKey = TagKey;   if(tagKey != HtmlTextWriterTag.Unknown)   {  output.RenderBeginTag(tagKey);    } else {  output.RenderBeginTag(this.TagName);   }  }

在WebControl基类中的RenderContents方法的实现示意性代码如下:

protected override void RenderContents(HtmlTextWriter output){    //使用默认逻辑来呈现子控件,那么一定要调用基类中的方法。    base.Render(output);  }

分析以上代码可以得出以下结论:

一、为了在由WebControl派生的类中实现控件呈现,必须重写AddAttributesToRender、RenderBeginTag、RenderEndTag、RenderContents等方法中的一个或者多个,而不必重写Render方法。

二、重写AddAttributesToRender、RenderBeginTag、RenderEndTag、RenderContents等方法非常重要(请注意重写这些方法的条件及注意事项),否则服务器控件可能会出现丢失标签的情况,这将严重影响服务器控件的呈现。

三、当呈现ASP.NET服务器控件标签中的内容时,必须重写RenderContents方法。

上述内容就是ASP.NET中RenderContents控件的作用是什么,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


当前题目:ASP.NET中RenderContents控件的作用是什么
网页网址:http://bzwzjz.com/article/pcohps.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都营销网站制作 成都网站建设 成都网站建设 网站设计 成都网站设计 定制网站设计 成都网站设计制作公司 成都网站设计公司 定制级高端网站建设 成都网站建设 成都响应式网站建设 重庆网站建设 企业手机网站建设 成都网站制作 定制网站制作 重庆网站制作 成都网站建设公司 定制网站设计 网站设计公司 宜宾网站设计 成都网站建设公司 成都网站建设