理解asp.net页面事件

   

     一个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方法,还会得到一个“响应在此上下文中不可用。”的错误警告。

了解了页面事件的触发顺序,在实际网站的开发中,我们就可以根据需要在不同的事件发生时给出处理操作。

 

posted @ 2010-06-07 16:12  唔愛吃蘋果  阅读(325)  评论(0编辑  收藏  举报