zoukankan      html  css  js  c++  java
  • 自定义控件(1)

    今天看了下有关控件呈现的问题。做个笔记,免得遗忘了,就不好了。

    DOTNET类库里,服务器控件都继承自System.Web.UI.Controls.Control类,该类提供了Render, RenderChildren,RenderControl等3种方法实现控件呈现。这些方法都使用HtmlTextWriter的实例做为参数,它们允许为一个HtmlTextWriter对象提供服务器控件的内容,并将其内容封装至HTTP输出流中输出到客户端显示。

    方法原型:
            protected virtual void Render(HtmlTextWriter writer);
            protected virtual void RenderChildren(HtmlTextWriter writer);
            protected virtual void RenderControl(HtmlTextWriter writer);
    实际上3个方法之间存在着密切的关系。下面的代码说明了3种方法之间的联系。
            //RenderCotrol 方法的基本实现
            public void RenderControl(HtmlTextWriter output)
            {
                if(Visible)
                    Render(output);
            }

            //Render 方法的基本实现
            public void Render(HtmlTextWriter output)
            {
                RenderChildren(output);
            }

            //RenderChildren 方法的基本实现
            public void RenderChildren(HtmlTextWriter output)
            {
                foreach(Control c in Controls)
                    c.RenderControl(output);
            }


    上面的代码说明了RenderControl、Render、RenderChildren方法的基本实现,同时也说明了空间呈现的大致逻辑。实际上,控件呈现是一个递归调用的过程,其过程为:
        页面框架建立一个HtmlTextWriter类的实例;
        页面框架将这个实例对象传递给RenderControl方法:
        RenderControl方法检查控件的可视书香Visible是否为true,如果为true,RenderControl方法将调用Render方法;如果为false,则不呈现该控件和其子控件;
        Render方法执行默认实现,调用RenderChildren方法;
        RenderChildren方法按照默认实现中的设定调用每个子控件的RenderControl方法。

    以上3种方法中最重要、最常用的是Render方法。空间开发者可以通过重写Render方法完成呈现控件的任务。存在两种方式将需要输出的内容封装入HTTP输出流中。
        ·  调用Write方法。这个方法将直接把需要输出的内容写入字符串中。
        ·  调用HtmlTextWriter类中提供的多种方法和相关枚举来组织需要输出的内容,而不是像Write方法那样直接编写标记文本。
  • 相关阅读:
    kthread_run
    05 七段数码管的实现
    Docker 面临的安全隐患,我们该如何应对
    7 天玩转 ASP.NET MVC — 第 6 天
    哪些问题困扰着我们?DevOps 使用建议
    如何使用 OneAPM 监控微软 Azure Cloud Service ?
    在 Java 中如何更高效地存储和管理 SQL 语句?
    规模化敏捷开发的10个最佳实践(上)
    如何在 Swift 语言下使用 iOS Charts API 制作漂亮图表?
    PHP 性能分析与实验——性能的宏观分析
  • 原文地址:https://www.cnblogs.com/yfalcon/p/413807.html
Copyright © 2011-2022 走看看