首页 > 代码库 > C# 问题解决思路--《数组bytes未定义》,ASP.NET页面加载顺序
C# 问题解决思路--《数组bytes未定义》,ASP.NET页面加载顺序
好久没写博客了,废话不多说,直接说问题。
问题发生情况,首先这个是老项目,然后我是第一次修改。当我解决了各种引用,数据库配置之后等类似的问题,我启动的项目的时候,无任何问题,但是当我点击页面的按钮的时候,就报类型的错误。
因此,我按照我个人的经验,做出排查。
1、首先是代码问题,我根据按钮找到对应的后台事件,然后加上断点,发现根本就不进对应的断点。(说明不是按钮的后台代码的错误)
2、有可能是整个页面的后台代码的其他的错误,因此我搜索了该后台代码 看是否哪里出现了 bytes这个数组,结果没有找到。(说明不是该页面的后台代码的错误)
3、该页面是集成另一个公共页面 basePage,于是我在basePage初始化的pageLoad事件里面加上了断点,结果发现,也不进页面,所以排除了继承的初始页面的问题。
4、按理说报的错误其实是不应该为前台代码的错误的,但是为了保险起见,我还是搜索了一下对应的前台代码,发现也没有任何地方是用到bytes这个数组变量的(因此排除了是后台代码的错误)
5、最后,我觉得可能是页面上某些特殊控件的原因,最后我将页面上的fck编辑器等几个特殊空间的和javascript的引用都注释了,后台代码也跟着注释了,发现也没有解决对应的问题。
6、上述我都检查过了,但是还是不知道是哪里出的问题,最终在项目经理永哥的帮助下,才知道配置文件中,在应用程序中配置了 HTTP 模块
<httpModules>
<add name="WebbHttpModule" type="Means.Component.WebUpload.WebbHttpModule, Means.Component"/>
</httpModules>
<httpHandlers>
<add verb="*" path="progress.ashx" type="Means.Component.WebUpload.WebbUploadStatusHandler, Means.Component" />
</httpHandlers>
问题就处在了这几个模块里面,讲这两行配置给注释掉之后,就不会出现问题了。实在是经验不足的问题。
母版页和内容页都可以包含控件的事件处理程序。对于控件而言,事件是在本地处理的,即内容页中的控件在内容页中引发事件,母版页中的控件在母版页中引发事件。控件事件不会从内容页发送到母版页。同样,也不能在内容页中处理来自母版页控件的事件。
在某些情况下,内容页和母版页中会引发相同的事件。例如,两者都引发 Init 和 Load 事件。引发事件的一般规则是初始化事件从最里面的控件向最外面的控件引发,所有其他事件则从最外面的控件向最里面的控件引发。请记住,母版页会合并到内容页中并被视为内容页中的一个控件,这一点十分有用。
下面是母版页与内容页合并后事件的发生顺序:
母版页控件 Init 事件。
内容控件 Init 事件。
母版页 Init 事件。
内容页 Init 事件。
内容页 Load 事件。
母版页 Load 事件。
内容控件 Load 事件。
内容页 PreRender 事件。
母版页 PreRender 事件。
母版页控件 PreRender 事件。
内容控件 PreRender 事件。
母版页和内容页中的事件顺序对于页面开发人员并不重要。但是,如果您创建的事件处理程序取决于某些事件的可用性,那么您将发现,了解母版页和内容页中的事件顺序很有帮助。
是,如果您创建的事件处理程序取决于某些事件的可用性,那么您将发现,了解母版页和内容页中的事件顺序很有帮助。
关于asp.net中页面事件加载的先后顺序
Page 执行中将按照如下顺序激活事件:
Page.PreInit
Page.Init
Page.InitComplite
Page.PreLoad
Page.Load
Page.LoadComplete
Page.PreRender
Page.PreRenderComplete
如果页面从另一个页面继承,如BasePage:System.Web.UI.Page,在BasePage中做了一些扩展,如权限检查,而其他页面从BasePage继承,则BasePage和最终Page的事件激活顺序是:
UI.PreInit
Page.PreInit
UI.Init
Page.Init
UI.InitComplite
Page.InitComplite
UI.PreLoad
Page.PreLoad
UI.Load
Page.Load
UI.LoadComplete
Page.LoadComplete
UI.PreRender
Page.PreRender
UI.PreRenderComplete
Page.PreRenderComplete
如果使用了MasterPage,则MasterPage中的事件和ContentPage中的事件按照下面顺序激活:
ContentPage.PreInit
Master.Init
ContentPage.Init
ContentPage.InitComplite
ContentPage.PreLoad
ContentPage.Load
Master.Load
ContentPage.LoadComplete
ContentPage.PreRender
Master.PreRender
ContentPage.PreRenderComplete
更进一步,如果ContentPage继承BasePage,那么,各事件的执行顺序将变成:
UI.PreInit
ContentPage.PreInit
Master.Init
UI.Init
ContentPage.Init
UI.InitComplite
ContentPage.InitComplite
UI.PreLoad
ContentPage.PreLoad
UI.Load
ContentPage.Load
Master.Load
UI.LoadComplete
ContentPage.LoadComplete
UI.PreRender
ContentPage.PreRender
Master.PreRender
UI.PreRenderComplete
ContentPage.PreRenderComplete
浏览下来发现并不是我现在所学的asp.net 1.1,估计应该是asp.net 2.0,
不过也没有关系,这让我知道了他们有继承时加载的顺序。
即:先加载继承页的,在加载自己的,如果继承页有继承则先加载继承页的继承。
其实是个很简单的内容。顺便写下Page事件(不知道1.1是不是就这些)
事件处理器名称 | 发生时间 |
Page_Init | 在Web窗体的视图状态加载服务器控件并对其初始化。 这是web窗体生命周期的第一步 |
Page_Load | 在Page对象上载入服务器控件。由于此时视图状态信息是可以使用的, 因此载这里可以用代码来改变空间的设置或者载页面上显示文本。 |
Page_PreRender | 应用程序将要呈现Page对象 |
Page_Unload | 页面从内存中卸载 |
Page_Error | 发生未处理的异常 |
Page_AbortTransaction | 事务处理被终止 |
Page_CommitTransaction | 事务处理被接受 |
Page_DataBinding | 把页面上的服务器空间和数据源绑定载一起 |
Page_Disposed | Page对象从内存中释放掉。这是Page对象生命周期中的最后一个事件 |
Init,Load,PreRender事件执行顺序:
1)控件的Init事件
2)控件所在页面的Init事件
3)控件所在页面的Load事件
4)控件的Load事件
5)控件所在页面的PreRender事件
6)控件的PreRender事件
规律:
1)Init事件从最里面的控件(包括用户控件及普通控件)向最外面的控件(页面)引发,Load及PreRender等其他事件从最外面的控件向最里面的控件引发;
2)控件之间相同事件的执行顺序依控件在页面的位置按从左到右,从上到下的先后顺序执行。
注意:
1)切记用户控件也被视为页面中的一个控件;
2)把用户控件作为单独的一个特殊页面来看,它本身及其所包含的控件同样遵守相同的规律;
3)有时在客户端程序(如javascript)中会用到客户端body对像的onload事件,注意这个客户端事件是最后执行,即在服务器端所有事件执行完后才执行。
===================================================================================
转载一篇关于页面对象模型的文章,说得比较详细,有助理解。没事的时候就多看两遍,慢慢体会:)。
ASP.NET 页面对象模型 |
Dino Esposito Wintellect 2003 年 8 月 |
|
C# 问题解决思路--《数组bytes未定义》,ASP.NET页面加载顺序