第一篇 就先转别人的博客 加上 msdn的资料 合起来一起  效果比较好

了解页生命周期非常重要,因为这样做您就能在生命周期的合适阶段编写代码,以达到预期效果。

控件的生命周期基于页的生命周期,但是页引发许多您需要在自定义控件中处理的事件。

本主题包含以下各节:

IIS 7.0 的 ASP.NET 应用程序生命周期概述(ASP.NET 应用程序生命周期简介)。

 控件)与整页回发过程中的页生命周期是一样。

 

阶段

说明

页请求

用户请求页时,ASP.NET 将确定是否需要分析和编译页(从而开始页的生命周期),或者是否可以在不运行页的情况下发送页的缓存版本以进行响应。

启动

 属性。

初始化

如果当前请求是回发请求,则回发数据尚未加载,并且控件属性值尚未还原为视图状态中的值。

加载

加载期间,如果当前请求是回发请求,则将使用从视图状态和控件状态恢复的信息加载控件属性。

回发事件处理

 属性。

呈现

 对象中。

卸载

Request)并执行清理。

onclick)或以使用代码的方式,均可将事件处理程序绑定到事件。

ASP.NET Web 服务器控件事件模型

开发自定义 ASP.NET 服务器控件

 

页事件

典型使用

PreInit

在启动阶段完成之后、初始化阶段开始之前引发。

使用该事件来执行下列操作:

  •  属性。

  • 创建或重新创建动态控件。

  • 动态设置主控页。

  •  属性。

  • 读取或设置配置文件属性值。

    注意
    如果在此阶段设置控件属性,则其值可能会在下一事件中被覆盖。

Init

 事件之前发生。

使用该事件来读取或初始化控件属性。

InitComplete

 事件后立即开启视图状态跟踪。

使用此事件对要在下一个回发后务必保留的视图状态进行更改。

PreLoad

 实例包括的回发数据之后引发。

Load

 事件之后发生。

 事件方法来设置控件中的属性并建立数据库连接。

控件事件

 事件。

注意
 属性。

LoadComplete

在事件处理阶段结束时引发。

对需要加载页上的所有其他控件的任务使用该事件。

PreRender

EnsureChildControls。)

 事件之后发生。

在呈现阶段开始之前,使用该事件对页或其控件的内容进行最后更改。

PreRenderComplete

数据绑定控件的数据绑定事件。

SaveStateComplete

此时对页或控件进行的任何更改都会影响呈现,但是在下一个回发中将不会检索到这些更改。

Render

 方法。

开发自定义 ASP.NET 服务器控件

用户控件(.ascx 文件)自动合并呈现,因此不需要在代码中显式呈现该控件。

Unload

首先针对每个控件引发,继而针对该页引发。

在控件中,使用该事件对特定控件执行最后清理,如关闭控件特定数据库连接。

对于页自身,使用该事件来执行最后清理工作,如:关闭打开的文件和数据库连接,或完成日志记录或其他请求特定任务。

注意
 方法),则该页将引发异常。

 事件在相应的页事件期间发生。

 事件之后。

MyBase.Load)以运行基实现。

在该图中方法和事件的顺序为从上到下排列,在每行中为从左到右。

 集合时所对应事件为止。

 控件)中与数据相关的事件。

 

控件事件

典型使用

DataBinding

 方法时发生。)

使用此事件可以手动打开数据库连接,如果需要,还可以在运行查询之前动态设置参数值。

 控件)

 事件之后引发。

 控件中的页眉或页脚行添加格式。

 控件)

 事件之后引发。

 属性,以便显示行或项中的相关数据。

DataBound

 控件中,会为所有行和子控件完成数据绑定。

“添加的控件的追赶事件”。)

嵌套的数据绑定控件

如果子控件中的数据根据容器控件中的数据绑定值执行了处理,这种情况则尤其显著。

SqlDataSource),后者在查询中使用公司 ID 来检索公司管理者数据。

 控件),因此它们的数据绑定阶段并不同步。

 控件才会绑定到其数据。

使用数据源控件绑定到数据

 控件事件与页生命周期的关联方式,可以使用下表中列出的事件。

 

控件事件

典型使用

LoggingIn

此事件标记登录过程的起点。

对必须在验证过程开始前发生的任务使用该事件。

Authenticate

 事件之后引发。

 控件的默认验证行为。

LoggedIn

在验证用户名和密码后引发。

如果出现错误或验证失败,就不会发生该事件。

LoginError

在身份验证失败的情况下引发。

使用该事件来设置控件中的问题解释文本或将用户定向到不同的页。



using
System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; public partial class _Default : Page { protected void Page_Load(object sender, EventArgs e) { } #region OnPreInit 第一步 protected override void OnPreInit(EventArgs e) { //检查 IsPostBack 属性来确定是不是第一次处理该页。 //创建或重新创建动态控件。 //动态设置主控页。 //动态设置 Theme 属性。 //读取或设置配置文件属性值。 //注意 //如果请求是回发请求,则控件的值尚未从视图状态还原。如果在此阶段设置控件属性,则其值可能会在下一事件中被重写。 base.OnPreInit(e); } #endregion #region OnInit 第二步 protected override void OnInit(EventArgs e) { //在所有控件都已初始化且已应用所有外观设置后引发。使用该事件来读取或初始化控件属性。 base.OnInit(e); } #endregion #region OnInitComplete 第三步 protected override void OnInitComplete(EventArgs e) { //由 Page 对象引发。使用该事件来处理要求先完成所有初始化工作的任务。 base.OnInitComplete(e); } #endregion #region PreLoad 第四步 protected override void OnPreLoad(EventArgs e) { //如果需要在 Load 事件之前对页或控件执行处理,请使用该事件。 //在 Page 引发该事件后,它会为自身和所有控件加载视图状态,然后会处理 Request 实例包括的任何回发数据。 base.OnPreLoad(e); } #endregion #region OnLoad 第五步 protected override void OnLoad(EventArgs e) { //Page 在 Page 上调用 OnLoad 事件方法,然后以递归方式对每个子控件执行相同操作,如此循环往复,直到加载完本页和所有控件为止。 //使用 OnLoad 事件方法来设置控件中的属性并建立数据库连接。 base.OnLoad(e); } #endregion #region 控件事件 第六步 protected void Button1_Click(object sender, EventArgs e) { //用这些事件来处理特定控件事件,如 Button 控件的 Click 事件或 TextBox 控件的 TextChanged 事件。 //注意 //在回发请求中,如果页包含验证程序控件,请在执行任何处理之前检查 Page 和各个验证控件的 IsValid 属性。 } #endregion #region OnLoadComplete 第七步 protected override void OnLoadComplete(EventArgs e) { //对需要加载页上的所有其他控件的任务使用该事件。 base.OnLoadComplete(e); } #endregion #region OnPreRender 第八步 protected override void OnPreRender(EventArgs e) { //在该事件发生前: //Page 对象会针对每个控件和页调用 EnsureChildControls。 //设置了 DataSourceID 属性的每个数据绑定控件会调用 DataBind 方法。有关更多信息,请参见下面的数据绑定控件的数据绑定事件。 //页上的每个控件都会发生 PreRender 事件。使用该事件对页或其控件的内容进行最后更改。 base.OnPreRender(e); } #endregion #region SaveStateComplete 第九步 protected override void OnSaveStateComplete(EventArgs e) { //在该事件发生前,已针对页和所有控件保存了 ViewState。将忽略此时对页或控件进行的任何更改。 //使用该事件执行满足以下条件的任务:要求已经保存了视图状态,但未对控件进行任何更改。 base.OnSaveStateComplete(e); } #endregion #region Render 第十步 //Render //这不是事件;在处理的这个阶段,Page 对象会在每个控件上调用此方法。所有 ASP.NET Web 服务器控件都有一个用于写出发送给浏览器的控件标记的 Render 方法。 //如果创建自定义控件,通常要重写此方法以输出控件的标记。不过,如果自定义控件只合并标准的 ASP.NET Web 服务器控件,不合并自定义标记,则不需要重写 Render 方法。有关更多信息,请参见开发自定义 ASP.NET 服务器控件。 //用户控件(.ascx 文件)自动合并呈现,因此不需要在代码中显式呈现该控件。 #endregion #region OnUnload 第十一步 protected override void OnUnload(EventArgs e) { //该事件首先针对每个控件发生,继而针对该页发生。在控件中,使用该事件对特定控件执行最后清理,如关闭控件特定数据库连接。 //对于页自身,使用该事件来执行最后清理工作,如:关闭打开的文件和数据库连接,或完成日志记录或其他请求特定任务。 //注意www.2cto.com //在卸载阶段,页及其控件已被呈现,因此无法对响应流做进一步更改。如果尝试调用方法(如 Response.Write 方法),则该页将引发异常。 base.OnUnload(e); } #endregion }
ASP.NET 页生命周期概述 与 运行page页面时的事件执行顺序  【转】

当页面进行回发时,如点击按钮,以上事件都会重新执行一次,这时的执行顺序为:

1. OnPreInit 2. OnInit 3. OnInitComplete 4. OnPreLoad 5. Page_Load 6. OnLoad 7. Button_Click 8. OnLoadComplete 9. OnPreRender 可以看到,Button_Click事件位于OnLoad之后执行,可以测试一下:

ASP.NET 页生命周期概述 与 运行page页面时的事件执行顺序  【转】
public partial class TestControls : System.Web.UI.Page
    {
        static int count = 0;
        protected void Page_Load(object sender, EventArgs e)
        {
            Response.Write(count+ "Page_Load <br />");
            count++;
        }
        protected override void OnPreInit(EventArgs e)
        {
            base.OnPreInit(e);
            Response.Write(count + "OnPreInit <br />");
            count++;
        }
        protected override void OnInit(EventArgs e)
        {
            base.OnInit(e);
            Response.Write(count + "OnInit <br />");
            count++;
        }
        protected override void OnLoad(EventArgs e)
        {
            base.OnLoad(e);
            Response.Write(count + "OnLoad <br />");
            count++;
        }
        protected override void OnPreLoad(EventArgs e)
        {
            base.OnPreLoad(e);
            Response.Write(count + "OnPreLoad <br />");
            count++;
        }
        protected override void OnLoadComplete(EventArgs e)
        {
            base.OnLoadComplete(e);
            Response.Write(count + "OnLoadComplete <br />");
            count++;
        }
        protected override void OnInitComplete(EventArgs e)
        {
            base.OnInitComplete(e);
            Response.Write(count + "OnInitComplete <br />");
            count++;
        }
       protected override void OnUnload(EventArgs e)
        {
            base.OnUnload(e);
        }
        protected override void OnDataBinding(EventArgs e)
        {
            base.OnDataBinding(e);
            Response.Write(count + "OnDataBinding <br />");
            count++;
        }
        protected override void OnPreRender(EventArgs e)
        {
            base.OnPreRender(e);
            Response.Write(count + "OnPreRender <br />");
            count++;
        }
        protected void btnGraphics_Click(object sender, EventArgs e)
        {
            //Bitmap bmp = new Bitmap(10, 10);
            //Graphics g = Graphics.FromImage(bmp);
            Response.Write(count + "btnGraphics_Click <br />");
            count++;
        }
    }
ASP.NET 页生命周期概述 与 运行page页面时的事件执行顺序  【转】

1.熟悉请求管道实现程序运行的全过程:

(1):BeginRequest: 开始处理请求 (2):AuthenticateRequest授权验证请求,获取用户授权信息 (3):PostAuthenticateRequest获取成功 (4): AunthorizeRequest 授权,一般来检查用户是否获得权限 (5):PostAuthorizeRequest:获得授权 (6):ResolveRequestCache:获取页面缓存结果 (7):PostResolveRequestCache 已获取缓存 (8):PostMapRequestHandler 创建页面对象 (9):AcquireRequestState 获取Session-----先判断当前页面对象是否实现了IRequiresSessionState接口,如果实现了,则从浏览器发来的请求报文体中获得SessionID,并到服务器的Session池中获得对应的Session对象,最后赋值给HttpContext的Session属性 (10)PostAcquireRequestState 获得Session (11)PreRequestHandlerExecute:准备执行页面对象 执行页面对象的ProcessRequest方法 (12)PostRequestHandlerExecute 执行完页面对象了 (13)ReleaseRequestState 释放请求状态 (14)PostReleaseRequestState 已释放请求状态 (15)UpdateRequestCache 更新缓存 (16)PostUpdateRequestCache 已更新缓存 (17)LogRequest 日志记录 (18)PostLogRequest 已完成日志 (19)EndRequest 完成、


ASP.NET 页生命周期概述 与 运行page页面时的事件执行顺序  【转】
public class getsession : System.Web.UI.Page,  IReadOnlySessionState
    {
        string ss = "";
        public void Init(HttpApplication context)
        {
            //这里可以根据需求,添加各个请求管道
            //获取Session
            context.AcquireRequestState += new EventHandler(context_AcquireRequestState);
            //获取Url
            context.BeginRequest += new EventHandler(context_BeginRequest);
        }
        void context_AcquireRequestState(object sender, EventArgs e)
        {
            if (Session["user"] != null)
            {
                ss = Session["user"].ToString();
            }
        
        }
        void context_BeginRequest(object sender, EventArgs e)
        {
            //获得当前页面请求管道的HttpApplication对象
            HttpApplication application = sender as HttpApplication;
            HttpContext context = application.Context;//获得上下文对象
            string url = context.Request.Url.LocalPath;//获得URL(不包含域名和路径)
        }
    }

相关文章: