阅读:1386回复:0
Asp.net2.0页面执行顺序
<P>今天碰到一个问题,在MasterPage的OnLoad中加入一个判断,希望在ContentPage的OnLoad之前执行,结果发现MasterPage的Onload在ContentPage的OnLoad后执行,后来把这个判断移动到MasterPage的OnInit中搞定</P>
<P>在一个单独的页面中,执行顺序为</P> <OL> <LI>PreInit <LI>Init <LI>InitComplete <LI>PreLoad <LI>Load <LI>LoadComplete <LI>PreRender <LI>PreRenderComplete </LI></OL> <P>在页面有MasterPage的时候 </P> <OL> <LI>ContentPage.PreInit <LI>Master.Init <LI>ContentPage.Init <LI>ContentPage.InitComplete <LI>ContentPage.PreLoad <LI ><FONT color=#ff0000>ContentPage.Load</FONT> <LI ><FONT color=#ff0000>Master.Load</FONT> <LI>ContentPage.LoadComplete <LI>ContentPage.PreRender <LI>Master.PreRender </LI></OL> <P>注意上面高亮的部分,除此之外其他的地方一般是先MasterPage后ContentPage,这里恰恰相反</P> <P>那么控件的加载和页面的几个事件的关系是什么呢? </P> <P>一般情况下,页面中的控件回先于OnInit执行,亦即 </P> <OL> <LI> Master中控件的Init <LI>ContentPage中控件的Init <LI>Master.Init <LI>Content.Init <LI>Content.Load <LI>Master.Load <LI>Master.中用户控件load <LI>ContentPage页面中的用户控件的 page_load </LI></OL> <P>可以看到控件的Init在Page的Init前执行,所以在Init中我们就可以放心使用页面中的控件了,但是下面的情况不同</P> <P>如果你的页面中使用WebControl,或者从WebControl继承的控件,WebControl需要使用CreateChildControls()来加载子控件,这个函数会在这个控件的Init后被调用,也就是说在一个WebControl的OnInit中,是没有办法直接使用其中的控件的,不过我们也可以自己用FindControl把控件加载进来,WebControl的其他方法的加载顺序见下表</P> <TABLE unselectable="on"> <TR bgColor=#333399></TR> <TR bgColor=#cccccc> <TD class=tabletext vAlign=top>Init</TD> <TD class=tabletext vAlign=top>You can use the OnInit method to trap this event and initialize member variables and other values.</TD></TR> <TR bgColor=#ffffcc> <TD class=tabletext vAlign=top>LoadViewState</TD> <TD class=tabletext vAlign=top>You can trap this event to customize how the control retrieves information from the ASP.NET hidden ViewState field.</TD></TR> <TR bgColor=#cccccc> <TD class=tabletext vAlign=top>Load</TD> <TD class=tabletext vAlign=top>This event is raised after you create and initialize the control. This is the best place to make the connection to the database or load document content. You can trap the Load event by adding the OnLoad method to the class.</TD></TR> <TR bgColor=#ffffcc> <TD class=tabletext vAlign=top>PreRender</TD> <TD class=tabletext vAlign=top>This event is raised before ASP.NET renders the control. Any changes to the control's state are saved into the hidden ViewState field.</TD></TR> <TR bgColor=#cccccc> <TD class=tabletext vAlign=top>SaveViewState</TD> <TD class=tabletext vAlign=top>This event is raised before the control state is persisted into the hidden ViewState field. You can trap the event to customize how this information is stored.</TD></TR> <TR bgColor=#ffffcc> <TD class=tabletext vAlign=top>Render</TD> <TD class=tabletext vAlign=top>You can use the Render method to respond to this event and specify the HTML code that represents the component's content.</TD></TR> <TR bgColor=#cccccc> <TD class=tabletext vAlign=top>Dispose</TD> <TD class=tabletext vAlign=top>This event is useful for cleanup operations. It's raised before the control is torn down and is the best place to free the resources created during the load phase.</TD></TR> <TR bgColor=#ffffcc> <TD class=tabletext vAlign=top>Unload</TD> <TD class=tabletext vAlign=top>This event is raised before the control is torn down. The official documentation says not to use this event to perform cleanup, and to rely on the Dispose event instead.</TD></TR></TABLE> |
|
|