OnInit与Page_Init区别

OnInit  是用户控件的 事件
和 Page_Init   页面事件!!

OnInit > Page_Init

的确OnInit是最先执行的,
         override protected void OnInit(EventArgs e)
         {
              //
              // CODEGEN:该调用是 ASP.NET Web 窗体设计器所必需的。
              //
              InitializeComponent();
              base.OnInit(e);
         }



  加载

         加载对应Load事件和OnLoad方法,对于这个事件,相信大多数朋友都会比较熟悉,用VS.Net生成的页面中的Page_Load方法就是响应Load事件的方法,对于每一次请求,Load事件都会触发,Page_Load方法也就会执行,相信这也是大多数人了解ASP.Net的第一步。

         Page_Load方法响应了Load事件,这个事件是在System.Web.WebControl.Control类中定义的(这个类是Page和所有服务器控件的祖宗),并且在OnLoad方法中被触发。

 

         很多人可能碰到过这样的事情,写了一个PageBase类,然后在Page_Load中来验证用户信息,结果发现不管验证是否成功,子类页面的Page_Load总是会先执行,这个时候很可能留下一些安全性的隐患,用户可能在没有得到验证的情况下就执行了子类中的Page_Load方法。

         出现这个问题的原因很简单,因为Page_Load方法是在OnInit中被添加到Load事件中的,而子类的OnInit方法中是先添加了Load事件,然后再调用base.OnInit,这样就造成了子类的Page_Load被先添加,那么先执行了。

         要解决这个问题也很简单,有两种方法:

1)   在PageBase中重载OnLoad方法,然后在OnLoad中验证用户,然后调用base.OnLoad,因为Load事件是在OnLoad中触发,这样我们就可以保证在触发Load事件之前验证用户。

2)   在子类的OnInit方法中先调用base.OnInit,这样来保证父类先执行Page_Load



/
关于Page.ProcessRequest(HttpApplication类也有,可我不知道它们有什么区别)的基本处理过程是:

private void ProcessRequest() 
{
   // 确定请求是否是回发 (postback)
IsPostBack = DeterminePostBackMode();

// 触发 ASPX 源代码的 Page_Init 事件
PageInit();

// 加载 ViewState,处理已发送的值。
if (IsPostBack) {
   LoadPageViewState();
ProcessPostData();
}   

// 触发 ASPX 源代码的 Page_Load 事件
PageLoad();




主要就是父类和子类间OnLoad,OnInit,Load 事件,Init事件的执行先后问题。

一个页面(子类)的Oninit方法最先启动执行,而后递归执行父类中Oninit方法,父类Oninit方法中添加Init事件,执行Page_Init方法,后再返回父类Oninit方法执行完毕,最后返回子类Oninit方法执行完毕,再执行子类Onload方法,而后递归执行父类中Onload方法,父类Onload方法中添加Load事件,执行Page_Load方法,后再返回父类Onload方法执行完毕,最后返回子类Oninit方法执行完毕,这样才执行完了。

如下父类:

public class PageBase:System.Web.UI.Page
{
protected override void OnLoad(EventArgs e)
{
string ss = "1";

base.OnLoad(e);
}
protected override void OnInit(EventArgs e)
{
base.OnInit(e);
}


}

子类:

public partial class _Default :PageBase
{
protected void Page_Load(object sender, EventArgs e)
{

}
protected void Page_Init(object sender, EventArgs e)
{
// Do any related intialization work.
}

protected override void OnInit(EventArgs e)
{

base.OnInit(e);
}


protected override void OnLoad(EventArgs e)
{
base.OnLoad(e);
}
}

整个过程是:

最先执行子类_Default 的OnInit的方法,这里调用父类PageBase的OnInit方法,在PageBase的OnInit方法内注册Init事件,执行Page_Init方法,而后返回至父类PageBase的OnInit方法终执行完毕,返回子类Oninit方法执行完毕;接着调用子类_Default 的Onload的方法,这里调用父类PageBase的Onload方法,在PageBase的Onload方法内注册Load事件,执行Page_Load方法,而后返回至父类PageBase的Onload方法终执行完毕,返回子类Onload方法执行完毕。

具体页面的执行过程还有很多工作,怎么做的,我摘抄别人的文章,不再写啦,以方便有需要的和我自己。O(∩_∩)O~

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


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值