ASP.NET 页生命周期概述
转载自:http://msdn.microsoft.com/zh-cn/library/ms178472.aspx
一.常规页生命周期阶段
示意图:
一般来说,页要经历下表概述的各个阶段。 除了页生命周期阶段以外,在请求前后还存在应用程序阶段,但是这些阶段并不特定于页。同时生命周期的某些部分仅当页处理为回发时才出现。
|
阶段 |
说明 |
|---|---|
|
页请求 |
页请求发生在页生命周期开始之前。 用户请求页时,ASP.NET 将确定是否需要分析和编译页 |
|
启动 |
在启动阶段,将设置页属性,如 Request 和 Response。 在此阶段,页还将确定请求是回发 |
|
初始化 |
页初始化期间,可以使用页中的控件,并将设置每个控件的 UniqueID 属性。 如果需要,还 |
|
加载 |
加载期间,如果当前请求是回发请求,则将使用从视图状态和控件状态恢复的信息加载控件属 |
|
回发事件处理 |
如果请求是回发请求,则将调用控件事件处理程序。 之后,将调用所有验证程序控件的 |
|
呈现 |
在呈现之前,会针对该页和所有控件保存视图状态。 在呈现阶段中,页会针对每个控件 |
|
卸载 |
完全呈现页并已将页发送至客户端、准备丢弃该页后,将引发 Unload 事件。 |
对应上图,我个人的理解如下:
页请求 <----> 第1步 浏览器将整个页面作为访问请求发送给IIS服务器,同时IIS也会进行初步判断,是否需要向服务器发起请求?
启动+初始化 <----> 第2、3步 IIS服务器先判断是否是postback操作,读取请求中的部分属性对服务器本地的页面文件进行设置(包括request、response、ispostback等), 同时还会初始化一些视图类的属性。注意在这个环节中,page_load方法被执行!
加载+回发事件处理 <----> 第4、5步 IIS服务器加载请求页面中的控件值等属性混合本地页面文件进行编译和处理。在这个环节,控件自定义方法被执行。
呈现 <----> 第6步 IIS服务器将编译好的HTML代码发送给浏览器,浏览器解释执行
卸载 在第6步结束以后 IIS服务器清空资源
二。生命周期事件
在页生命周期的每个阶段中,页将引发可运行您自己的代码进行处理的事件。 对于控件事件,通过以声明方式使用特性(如 onclick)或以使用代码的方式,均可将事件处理程序绑定到事件。
页还支持自动事件连接,即,ASP.NET 将查找具有特定名称的方法,并在引发了特定事件时自动运行这些方法。 如果 @ Page 指令的 AutoEventWireup 特性设置为 true,页事件将自动绑定至使用命名约定 Page_事件(如 Page_Load 和 Page_Init)的方法。 有关自动事件连接的更多信息,请参见 ASP.NET Web 服务器控件事件模型。
下表列出了最常用的页生命周期事件。 除了列出的事件外还有其他事件;不过,大多数页处理方案不使用这些事件。 而是主要由 ASP.NET 网页上的服务器控件使用,以初始化和呈现它们本身。 如果要编写自定义 ASP.NET 服务器控件,则需要详细了解这些事件。 有关创建自定义控件的信息,请参见开发自定义 ASP.NET 服务器控件。
|
页事件 |
典型使用 |
|---|---|
|
在启动阶段完成之后、初始化阶段开始之前引发。 使用该事件来执行下列操作:
|
|
|
在所有控件都已初始化且已应用所有外观设置后引发。 各个控件的 Init 事件在页的 Init |
|
|
在页的初始化阶段结束时引发。 Init 和 InitComplete 事件之间仅发生一个操作:开启 |
|
|
在页为自身和所有控件加载视图状态之后以及处理 Request 实例包括的回发数据之后引发。 |
|
|
Page 对象对 Page 对象调用 OnLoad 方法,然后以递归方式对每个子控件执行相同操作, 使用 OnLoad 事件方法来设置控件中的属性并建立数据库连接。 |
|
|
控件事件 |
使用这些事件来处理特定控件事件,如 Button 控件的 Click 事件或 TextBox 控件的 |
|
在事件处理阶段结束时引发。 对需要加载页上的所有其他控件的任务使用该事件。 |
|
|
在 Page 对象创建呈现页所需的所有控件(包括组合控件的子控件)之后引发。 在呈现阶段开始之前,使用该事件对页或其控件的内容进行最后更改。 |
|
|
在设置了 DataSourceID 属性的每个数据绑定控件调用其 DataBind 方法之后引发。 |
|
|
在为页和所有控件保存视图状态和控件状态之后发生。 此时对页或控件进行的任何 |
|
|
这不是事件;在处理的这个阶段,Page 对象会在每个控件上调用此方法。 所有
如果创建自定义控件,通常要覆盖此方法以输出控件的标记。 不过,如果自定义 用户控件(.ascx 文件)自动合并呈现,因此不需要在代码中显式呈现该控件。 |
|
|
首先针对每个控件引发,继而针对该页引发。 在控件中,使用该事件对特定控件执行最后清理,如关闭控件特定数据库连接。
对于页自身,使用该事件来执行最后清理工作,如:关闭打开的文件和数据库连接, 注意在卸载阶段,页及其控件已被呈现,因此无法对响应流做进一步更改。
如果尝试调用方法(如 Response.Write 方法),则该页将引发异常。 |
注意
浙公网安备 33010602011771号