复合控件Asp.net2.0

每次都从最原始的方法去写一些复杂的控件是不是很郁闷呢?

如何可以简单的利用现有的控件来制作复合控件呢?

一个很简单的例子看一下就明白了。
 1 [ToolboxData("<{0}:WebCustomControl1 runat=server></{0}:WebCustomControl1>")]
 2    public class WebCustomControl1 : CompositeControl
 3    {
 4        public TextBox txt1 = new TextBox();
 5        public Label lab = new Label();
 6        public Button b = new Button();
 7        public WebCustomControl1()
 8        {
 9            b.Text = "Click me";
10            txt1.ID = "kkk";
11            b.Click += new EventHandler(b_Click);
12        }

13 
14        void b_Click(object sender, EventArgs e)
15        {
16            lab.Text = txt1.Text;
17        }

18
19        protected override void OnInit(EventArgs e)
20        {
21           
22          
23            base.OnInit(e);
24        }

25
26        protected override void CreateChildControls()
27        {
28            this.Controls.Add(txt1);
29            this.Controls.Add(lab);
30            this.Controls.Add(b);
31           
32        }

33        protected override void RenderChildren(HtmlTextWriter writer)
34        {
35            txt1.RenderControl(writer);
36            b.RenderControl(writer);
37            lab.RenderControl(writer);
38           
39        }

40        protected override HtmlTextWriterTag TagKey
41        {
42            get
43            {
44                return HtmlTextWriterTag.Div;
45            }

46        }

控件的生命周期
 (1)初始化-- --在此阶段中,主要完成两项工作:一、初始化在传入Web请求生命周期内所需的设置;二、跟踪视图状态。首先,页面框架通过默认方式引发Init事件,并调用OnInit()方法,控件开发人员可以重写该方法为控件提供初始化逻辑。此后,页面框架将调用TrackViewState方法来跟踪视图状态。需要注意的是:多数情况下,Control基类提供的TrackViewState方法实现已经足够了。只有在控件定义了复杂属性时,开发人员才可能需要重写TrackViewState方法。

  (2)加载视图状态----此阶段的主要任务是检查服务器控件是否存在以及是否需要将其状态恢复到它在处理之前的请求结束的状态。因此该过程发生在页面回传过程中,而不是初始化请求过程。在此阶段,页面框架将自动恢复ViewState字典。如果服务器控件不维持其状态,或者它有能力通过默认方式保存其所有状态而使用ViewState字典,那么开发人员则不必实现任何逻辑。针对那些无法在 ViewState字典中存储的数据类型或者需要自定义状态管理的情况,开发人员可以通过重写LoadViewState方法来自定义状态的恢复和管理。

  (3)处理回发数据----若要使控件能够检查客户端发回的窗体数据,那么必须实现System.Web.UI.IPostBackDataHandler接口的 LoadPostData()方法。因此只有处理回发数据的控件参与此阶段。

  (4)加载----至此阶段开始,控件树中的服务器控件已创建并初始化、状态已还原并且窗体控件反映了客户端的数据。此时,开发人员可以通过重写OnLoad()方法来实现每个请求共同的逻辑。

  (5)发送回发更改通知----在此阶段,服务器控件通过引发事件作为一种信号,表明由于回发而发生的控件状态变化(因此该阶段仅用于回发过程)。为了建立这种信号,开发人员必须再次使用System.Web.UI.IPostBackDataHandler接口,并实现另一方法- RaisePostBackChangedEvent()。其判断过程为:如果控件状态因回发而更改,则LoadPostData()返回true;否则返回false。页面框架跟踪所有返回true的控件并在这些控件上调用RaisePostDataChangedEvent()。

  (6)处理回发事件----该阶段处理引起回发的客户端事件。为了便于将客户端事件映射到服务器端事件上进行处理,开发人员在此阶段可以通过实现 System.Web.UI.IPostBackEventHandler接口的RaisePostBackEvent()方法来实现该逻辑。由此途径,服务器控件将成功捕获回发的客户端事件进行服务器端的相应处理。

  (7)预呈现----该阶段完成在生成控件之前所需要的任何工作。通常情况下是通过重写OnPreRender()方法完成该工作。需要注意的是:在该阶段,可以保存在预呈现阶段对控件状态所做的更改,而在呈现阶段进行的更改则会丢失。

  (8)保存状态----如果服务器控件不维持状态,或者它有能力通过默认方式保存其所有状态而使用ViewState字典,那么开发人员不必在该阶段实现任何逻辑。因为这个保存状态的过程是自动的。如果服务器控件需要自定义状态保存,或者控件无法在ViewState字典中存储特殊的数据类型,则需要通过重写SaveViewState()方法来实现状态保存。

  (9)呈现----表示向HTTP输出流中写入标记文本的过程。开发人员通过重写Render()方法使其在输出流上自定义标记文本。

  (10)处置----在此阶段中,通过重写Dispose ()方法完成释放对昂贵资源的引用,如数据库链接等。

  (11)卸载----完成的工作与"处置"阶段相同,但是,开发人员通常在Dispose()方法中执行清除,而不处理Unload事件



附注:在页面中动态添加子控件时候也不要放在page_load里。可以放在override oninit里面。
asp.net生命周期

一.预初始化对象(OnPreInit)
二.初始化对象(OnInit)
三.完成初始化(OnInitComplete)
四.导入Viewstate数据(LoadViewState)
五.用LoadPostData处理Postback数据(LoadPostData
六.OnPreLoad
七.导入对象(OnLoad)
八.RaisePostBackChanged事件(RaisePostDataChangedEvent)
九.处理客户端PostBack事件(RaisePostBackEvent)
十.Page_OnLoadComplete十一.预先呈递对象 OnPreRender
十二.完成预呈现(OnPreRenderComplete)
十三.保存ControlState(SaveControlState)

原文地址:https://www.cnblogs.com/lovebanyi/p/1158438.html