ASP.NET page cycle
Each request for an .aspx page that hits IIS is handed over to the HTTP Pipeline. The HTTP Pipeline is a chain of managed objects that sequentially process the request and convert it to plain HTML text content. The starting point of a HTTP Pipeline is the HttpRuntime class. The ASP.NET infrastructure creates each instance of this class per AppDomain hosted within the worker process. The HttpRuntime class picks up an HttpApplication object from an internal pool and sets it to work on the request. It determines what class handles the request. The association between the resources and handlers are stored in the configurable file of the application. In web.config and also inmachine.config you will find these lines in section.
If you run through the following program then it will be much easier to follow:
<add verb="*" path="*.aspx" type="System.Web.UI.PageHandlerFactory"/>
This extension can be associated with HandlerClass or HandlerFactory class. HttpApplicationobject gets the page object that implements the IHttpHandler Interface. The process of generating the output to the browser is started when the object calls the ProcessRequest method.
Page Life Cycle
Once the HTTP page handler class is fully identified, the ASP.NET runtime calls the handler's ProcessRequest to start the process. This implementation begins by calling the methodFrameworkInitialize(), that builds the control trees for the page. This is a protected and virtual member of the TemplateControl class, the class from which the page itself derives.
Next processRequest() makes the page transition through various phases: initialization, the loading of viewstate and postback data, the loading of the page's user code and the execution of postback server-side events. Then the page enters into render mode, the viewstate is updated and the HTML is generated and sent to the output console. Finally the page is unloaded and the request is considered completely served.
Stages and corresponding events in the life cycle of the ASP.NET page cycle:
If you run through the following program then it will be much easier to follow:
<add verb="*" path="*.aspx" type="System.Web.UI.PageHandlerFactory"/>
This extension can be associated with HandlerClass or HandlerFactory class. HttpApplicationobject gets the page object that implements the IHttpHandler Interface. The process of generating the output to the browser is started when the object calls the ProcessRequest method.
Page Life Cycle
Once the HTTP page handler class is fully identified, the ASP.NET runtime calls the handler's ProcessRequest to start the process. This implementation begins by calling the methodFrameworkInitialize(), that builds the control trees for the page. This is a protected and virtual member of the TemplateControl class, the class from which the page itself derives.
Next processRequest() makes the page transition through various phases: initialization, the loading of viewstate and postback data, the loading of the page's user code and the execution of postback server-side events. Then the page enters into render mode, the viewstate is updated and the HTML is generated and sent to the output console. Finally the page is unloaded and the request is considered completely served.
Stages and corresponding events in the life cycle of the ASP.NET page cycle:
Stage | Events/Method |
Page Initialization | Page_Init |
View State Loading | LoadViewState |
Postback data processing | LoadPostData |
Page Loading | Page_Load |
PostBack Change Notification | RaisePostDataChangedEvent |
PostBack Event Handling | RaisePostBackEvent |
Page Pre Rendering Phase | Page_PreRender |
View State Saving | SaveViewState |
Page_Render | Page Rendering |
Page_UnLoad | Page Unloading |
Some of the events listed above are not visible at the page level. It will be visible if you happen to write server controls and write a class that is derived from page.
1. PreInit
The entry point of the page life cycle is the pre-initialization phase called "PreInit". This is the only event where programmatic access to master pages and themes is allowed. You can dynamically set the values of master pages and themes in this event. You can also dynamically create controls in this event.
Example: Override the event as given below in your code-behind cs file of your aspx page.
1. PreInit
The entry point of the page life cycle is the pre-initialization phase called "PreInit". This is the only event where programmatic access to master pages and themes is allowed. You can dynamically set the values of master pages and themes in this event. You can also dynamically create controls in this event.
Example: Override the event as given below in your code-behind cs file of your aspx page.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
public partial class _Default : System.Web.UI.Page
{
protected void Page_PreInit(object sender, EventArgs e)
{
// Use this event for the following:
// Check the IsPostBack property to determine whether this is the first time the page is being processed.
// Create or re-create dynamic controls.
// Set a master page dynamically.
// Set the Theme property dynamically.
}
2. Init
This event fires after each control has been initialized, each control's UniqueID is set and any skin settings have been applied. You can use this event to change initialization values for controls. The "Init" event is fired first for the most bottom control in the hierarchy, and then fired up the hierarchy until it is fired for the page itself.
Example : Override the event as given below in your code-behind cs file of your aspx page.
protected void Page_Init(object sender, EventArgs e)
{
// Raised after all controls have been initialized and any skin settings have been applied.
// Use this event to read or initialize control properties.
}
3. InitComplete
Raised once all initializations of the page and its controls have been completed. Until now the viewstate values are not yet loaded, hence you can use this event to make changes to view state that you want to ensure are persisted after the next postback.
Example : Override the event as given below in your code-behind cs file of your aspx page.
protected void Page_InitComplete(object sender, EventArgs e)
{
// Raised by the Page object. Use this event for processing tasks that require all initialization be complete.
}
4. PreLoad
Raised after the page loads the view state for itself and all controls and then processes postback data included with the Request instance.
Loads ViewState: ViewState data are loaded to controls
Note: The page viewstate is managed by ASP.NET and persists information over a page roundtrip to the server. Viewstate information is saved as a string of name/value pairs and contains information such as control text or value. The viewstate is held in the value property of a hidden control that is passed from page request to page request.
Loads Postback data: postback data are now handed to the page controls.
Note: During this phase of the page creation, form data that was posted to the server (termed postback data in ASP.NET) is processed against each control that requires it. Hence, the page fires the LoadPostData event and parses through the page to find each control and updates the control state with the correct postback data. ASP.NET updates the correct control by matching the control's unique ID with the name/value pair in the NameValueCollection. This is one reason that ASP.NET requires unique IDs for each control on any given page.
Example: Override the event as given below in your code-behind cs file of your aspx page.
protected override void OnPreLoad(EventArgs e)
{
// Use this event if you need to perform processing on your page or control before the Load event.
// Before the Page instance raises this event, it loads view state for itself and all controls, and
// then processes any postback data included with the Request instance.
}
5. Load
The important thing to note about this event is the fact that by now, the page has been restored to its previous state in case of postbacks. Code inside the page load event typically checks for PostBack and then sets control properties appropriately. This method is typically used for most code, since this is the first place in the page lifecycle that all values are restored. Most code checks the value of IsPostBack to avoid unnecessarily resetting state. You may also wish to call Validate and check the value of IsValid in this method. You can also create dynamic controls in this method.
Example: Override the event as given below in your code-behind cs file of your aspx page.
protected void Page_Load(object sender, EventArgs e)
{
// The Page calls the OnLoad event method on the Page, then recursively does the same for each child
// control, which does the same for each of its child controls until the page and all controls are loaded.
// Use the OnLoad event method to set properties in controls and establish database connections.
}
6. Control (PostBack) event(s)
ASP.NET now calls any events on the page or its controls that caused the PostBack to occur. This might be a button's click event or a dropdown's selectedindexchange event, for example.
These are the events, the code for which is written in your code-behind class (.cs file).
Example: Override the event as given below in your code-behind cs file of your aspx page.
protected void Button1_Click(object sender, EventArgs e)
{
// This is just an example of control event.. Here it is button click event that caused the postback
}
7. LoadComplete
This event signals the end of Load.
Example: Override the event as given below in your code-behind cs file of your aspx page.
protected void Page_LoadComplete(object sender, EventArgs e)
{
// Use this event for tasks that require that all other controls on the page be loaded.
}
8. PreRender
Allows final changes to the page or its control. This event takes place after all regular PostBack events have taken place. This event occurs before saving ViewState, so any changes made here are saved.
For example: After this event, you cannot change any property of a button or change any viewstate value. Because, after this event, the SaveStateComplete and Render events are called.
Example: Override the event as given below in your code-behind cs file of your aspx page.
protected override void OnPreRender(EventArgs e)
{
// Each data bound control whose DataSourceID property is set calls its DataBind method.
// The PreRender event occurs for each control on the page. Use the event to make final
// changes to the contents of the page or its controls.
}
9. SaveStateComplete
Prior to this event the view state for the page and its controls is set. Any changes to the page's controls at this point or beyond are ignored.
Example: Override the event as given below in your code-behind cs file of your aspx page.
protected override void OnSaveStateComplete(EventArgs e)
{
// Before this event occurs, ViewState has been saved for the page and for all controls.
// Any changes to the page or controls at this point will be ignored.
// Use this event perform tasks that require view state to be saved, but that do not make any changes to controls.
}
10. Render
This is a method of the page object and its controls (and not an event). At this point, ASP.NET calls this method on each of the page's controls to get its output. The Render method generates the client-side HTML, Dynamic Hypertext Markup Language (DHTML), and script that are necessary to properly display a control at the browser.
Note: Right-click on the web page displayed in the client's browser and view the page's source. You will not find any aspx server control in the code. Because all aspx controls are converted to their respective HTML representation. The browser is capable of displaying HTML and client-side scripts.
Example: Override the event as given below in your code-behind cs file of your aspx page.
// Render stage goes here. This is not an event
11. UnLoad
This event is used for cleanup code. After the page's HTML is rendered, the objects are disposed of. During this event, you should destroy any objects or references you have created in building the page. At this point, all processing has occurred and it is safe to dispose of any remaining objects, including the Page object.
Cleanup can be performed on:
(a)Instances of classes in other words objects
(b)Closing opened files
(c)Closing database connections.
Example: Override the event as given below in your code-behind cs file of your aspx page.
protected void Page_UnLoad(object sender, EventArgs e)
{
// This event occurs for each control and then for the page. In controls, use this event to do final cleanup
// for specific controls, such as closing control-specific database connections.
// During the unload stage, the page and its controls have been rendered, so you cannot make further
// changes to the response stream.
//If you attempt to call a method such as the Response.Write method, the page will throw an exception.
}
}
Comments
Post a Comment