一个ASP.NET页面在运行时将经历一个生命周期,在生命周期中将执行一系列处理步骤。这些步骤包括初始化、实例化控件、还原和维护状态、运行事件处理程序代码以及呈现页面。在页生命周期的每个阶段中将引发一些事件,事件被引发时会运行程序员提供的事件处理代码。页面还支持自动事件连接,即ASP.NET将寻找具有特定名称的方法,并在引发特定事件时自动运行这些方法。如果@Page指令的AutoEventWireup属性设置为 true(若未定义该属性则默认为 true),页面事件将自动绑定至使用“Page_event”命名约定的方法,如 Page_Load 和 Page_Init。下表列出了主要的页面生命周期事件。
页 事 件 | 典 型 用 场 |
Page_PreInit | 使用IsPostBack属性确定是否是第一次处理该页;创建动态控件;动态设置Theme属性;读取或设置配置文件属性值等 |
Page_Init | 读取或初始化控件属性 |
Page_Preload | 事件在所有回发数据处理之后但在 Load 事件之前引发 |
Page_Load | 读取和更新控件属性 |
Control events | 处理特定事件,如 Button 控件的 Click 事件 |
Page_PreRender | 对页的内容进行最后更改 |
Page_Unload | 执行最后的清理工作,例如关闭打开的文件和数据库连接等 |
以下代码可以用于验证这些事件的触发顺序:
代码清单 6‑1
- protected void Page_Load(object sender, EventArgs e)
-
- {
-
- lbText.Text += "Page_Load <hr> ";
-
- }
-
- protected void Page_PreInit(object sender, EventArgs e)
-
- {
-
- lbText.Text += "Page_PreInit <hr>";
-
- }
-
- protected void Page_Init(object sender, EventArgs e)
-
- {
-
- lbText.Text += "Page_Init <hr>";
-
- }
-
- protected void Page_PreLoad(object sender, EventArgs e)
-
- {
-
- lbText.Text += "Page_PreLoad <hr>";
-
- }
-
- protected void Page_PreRender(object sender, EventArgs e)
-
- {
-
- lbText.Text += "Page_PreRender <hr>";
-
- }
lbText是在页面顶端放置的一个Lable控件。运行后在浏览器中呈现如图6-1所示的效果。
需要特别说明的是Page_Unload事件,它容易被误解为关闭页面时所触发的事件。但是执行下面的代码后就会发现其实不然。
代码清单 6‑2
- protected void Page_Unload(object sender, EventArgs e)
-
- {
- System.Web.HttpContext.Current.Response.Write("<Script>alert('Page_Unload');</Script>");
- }
保存并运行页面后就会发现,在页面加载后就看到了图6-2的效果。
页面在请求完成后,就立刻触发了该事件。关闭页面是一个客户端的事件,请不要与之混淆。此外,如果在Page_Unload中调用Response.Write方法,还会得到一个“响应在此上下文中不可用。”的错误警告。
了解了页面事件的触发顺序,在实际网站的开发中,我们就可以根据需要在不同的事件发生时给出处理操作。