asp.net控件开发(一)-显示控件内容 |
||
本文标签:asp.net 控件 显示 开发 asp.net控件的显示自然会离不开输出HTML、CSS、Javascript等前台的显示内容,所以开发一个控件的时候第一件事就是要知道如何输出客户端要显示的内容 。 一、选择基类 asp.net中所有的标准控件都可以拿过来作为基类,如果我们要开发的控件只是对原有的标准控件做一些功能上的加强的话(如:你对TreeView的CheckBox添加一些随动的功能),就可以直接拿标准控件过来作为基类 。 一般的如果开发的控件从标准里面找不到合适的,可以从三个类中来继承: System.Web.UI.Control 下面介绍下这三个类的关系跟区别: Control:只提供简单的呈现,没有对css的支持 。如:Literal控件 三者的关系:Control是asp.net所有控件的基类 ,WebControl是从Control中继承而来,CompositeControl是从WebControl中继承而来 。 二、如何呈现 Control的呈现 Control类中的呈现是通过方法Render来实现的 。Render的原型: protected internal virtual void Render(HtmlTextWriter writer){...} HtmlTextWriter writer 参数是在运行时有调用Render方法的框架所提供,所以我们可以同过重写Render方法来实现内容的呈现 。 HelloWorld示例: public class HelloWorld : Control{ Control输出html内容 在Render方法中我们要实现输出html标签跟样式可以借助于:HtmlTextWriterTag、HtmlTextWriterAttribute、HtmlTextWriterStyle这三个枚举来实现 。HtmlTextWriterTag是表示Html标签,HtmlTextWriterAttribute是表示标签上的属性,HtmlTextWriterStyle是表示样式 。 Picture示例:
WebControl的呈现 WebControl的呈现分为三步:呈现开始标签、呈现标签中的内容、呈现结束标签,分别实现的方法为:RenderBeginTag、RenderContents、RenderEndTag 。RenderBeginTag所生成的标签是有WebControl.TagKey或则WebControl.TagName属性来决定的 。WebControl.TagKey的默认呈现标签为,所以如果我们要改变刚开始的呈现标签可以通过重写WebControl.TagKey或则WebControl.TagName来实现 。 注意的就是通常我们要对外围的标签进行控制时我们不会去重写RenderBeginTag方法,而是去重写TagKey属性 。另外如果我们重写了RenderBeginTag方法就一定要去重写RenderEndTag方法 。 另外WebControl提供了AddAttributeToRender方法来添加控件的属性 。需要注意的一点你重写AddAttributeToRender方法添加属性时,也要去调用base.AddAttributeToRender方法 。 我们用WebControl来实现上面的PicShow控件:
CompositeControl的呈现 因为CompositeControl继承于WebControl所以也有属性TagKey来决定开始的标签 。我们要实现CompositeControl的呈现只需添加域即可以,如我们的控件需要有TextBox控件可以表示为:private TextBox _txtInput 。然后通过重写CreateChildControls方法,通过this.Controls.Add方法来呈现 。 |