asp.net控件开发(一)-显示控件内容

 我来答
清宁时光17
2022-09-29 · TA获得超过1.4万个赞
知道大有可为答主
回答量:7304
采纳率:100%
帮助的人:43.4万
展开全部

  控件的显示自然会离不开输出HTML CSS Javascript等前台的显示内容 所以开发一个控件的时候第一件事就是要知道如何输出客户端要显示的内容

   一 选择基类

  中所有的标准控件都可以拿过来作为基类 如果我们要开发的控件只是对原有的标准控件做一些功能上的加强的话(如 你对TreeView的CheckBox添加一些随动的功能) 就可以直接拿标准控件过来作为基类

  一般的如果开发的控件从标准里面找不到合适的 可以从三个类中来继承

  System Web UI ControlSystem Web UI WebControls WebControlSystem Web UI WebControls CompositeControl

  下面介绍下这三个类的关系跟区别

  Control 只提供简单的呈现 没有对css的支持 如 Literal控件WebControl 建立了对控件外观的支持 适合可视化的控件来继承 如 ButtonCompositeControl 是派生多个控件复合的 适合开发应用中的标准控件

  三者的关系 Control是所有控件的基类 WebControl是从Control中继承而来 CompositeControl是从WebControl中继承而来

   二 如何呈现

   Control的呈现

  Control类中的呈现是通过方法Render来实现的 Render的原型

  protected internal virtual void Render(HtmlTextWriter writer){ }

  HtmlTextWriter writer 参数是在运行时有调用Render方法的框架所提供 所以我们可以同过重写Render方法来实现内容的呈现

  HelloWorld示例

  public class HelloWorld : Control{protected override void Render(HtmlTextWriter writer){writer WriteLine( Henllo World ); }}编译之后 在新的项目中添加对dll文件的使用 会呈现出 Hello World

   Control输出内容

  在Render方法中我们要实现输出标签跟样式可以借助于 HtmlTextWriterTag HtmlTextWriterAttribute HtmlTextWriterStyle这三个枚举来实现 HtmlTextWriterTag是表示Html标签 HtmlTextWriterAttribute是表示标签上的属性 HtmlTextWriterStyle是表示样式

  Picture示例

  

  public class PicShow : Control { protected override void Render(HtmlTextWriter writer) { writer AddStyleAttribute(HtmlTextWriterStyle TextAlign center ); writer AddStyleAttribute(HtmlTextWriterStyle Height px ); writer AddStyleAttribute(HtmlTextWriterStyle Width px ); writer RenderBeginTag(HtmlTextWriterTag Div); //Create Img Tag writer AddAttribute(HtmlTextWriterAttribute Src 你的图片地址 ); writer AddStyleAttribute(HtmlTextWriterStyle Width px ); writer AddStyleAttribute(HtmlTextWriterStyle Height px ); writer RenderBeginTag(HtmlTextWriterTag Img); writer RenderEndTag(); //End Of Div writer RenderEndTag(); } }

  当你指定好上面的图片地址后 就可以显示出指定的图片 同过查看源文件我们可以发现客户端生成的源代码就是我们所要创建的内容

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控件

  

  public class PictureWeb : WebControl { protected override HtmlTextWriterTag TagKey { get { return HtmlTextWriterTag Div; } } protected override void AddAttributesToRender(HtmlTextWriter writer) { base AddAttributesToRender(writer); writer AddStyleAttribute(HtmlTextWriterStyle TextAlign center ); writer AddStyleAttribute(HtmlTextWriterStyle Width px ); writer AddStyleAttribute(HtmlTextWriterStyle Height px ); } protected override void RenderContents(HtmlTextWriter writer) { writer AddAttribute(HtmlTextWriterAttribute Src 你的图片地址 ); writer AddStyleAttribute(HtmlTextWriterStyle Width px ); writer AddStyleAttribute(HtmlTextWriterStyle Height px ); writer RenderBeginTag(HtmlTextWriterTag Img); writer RenderEndTag(); } }

  在上面的代码中我们首先要创建div标签 所以修改TagKey属性 为了给外层的div添加属性所以重写了AddAttributesToRender方法 最后在呈现的Img在RenderContents方法中实现 创建外层的< DIV >跟结束的< /DIV >我们交给了RenderBeginTag跟RenderEndTag去实现而无需重写

   CompositeControl的呈现

lishixinzhi/Article/program/net/201311/11674

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式