PreInit
PreInit is the first phase in asp.net page life cycle events. This is the place where one can dynamically set their master page in the code. In such case you can also set any theme or skin to your page, in PreInit we can also set the properties of the server controls of Master page, like the code below:
PreInit is the first phase in asp.net page life cycle events. This is the place where one can dynamically set their master page in the code. In such case you can also set any theme or skin to your page, in PreInit we can also set the properties of the server controls of Master page, like the code below:
protected void Page_PreInit(object sender, EventArgs e)
{
if (textBox1
== null)
{
Response.Write("Pre Init, server control Not available");
}
else
{
string TextinInit
= textBox1.Text;
Response.Write("Pre
Init, Server Control enabled");
}
Page.MasterPageFile = "~/TestInitMaster.master";
TextBox _mstTextBox
= (TextBox)Page.Master.FindControl("txtMessage");
Label _mstLabel
= (Label)Page.Master.FindControl("lblMessage");
_mstLabel.Text = "Setted
in default page at time : " +ateTime.Now.ToString();
_mstTextBox.Text = "Textbox
set in default page";
}
In above you can see I’ve used
a master page dynamically and set a label and TextBox’s Text property of that
master page in runtime that means we can set the master page dynamically and
associate the values in their controls if any. If you try to set the masterpage
in any other event after Page_PreInit event, you will get an error message that
will tell you that the master page only can be set on or before Page_PreInit
event. In Page_PreInit event you can also see at the top level I’m checking a
TextBox1 value whether it’s null or not. It is a server control (TextBox), but
in PreInit the value will always be null of this text box or any other server
control. So if I want to conclude the thing, in Page_PreInit controls are not
fully initialized. So use this event for setting MasterPage file in your code.
Each control Unique ID’s are also available at this event.
Init
Init is called when you can initialize your page controls, this is the place that comes into picture after each Control initialization, till this event they get their Unique Id, master page etc. In Init you cannot access any controls properties after the last viewstate, I mean suppose you enter some text in a textbox control and click on a button control that makes a postback, now you want to view the value latest entered. In such case you will be able to see the textbox value which you’ve entered after the round trip happens, this is because of ViewState property of controls. That means they preserved your last saved value, but you see this value after Init phase because, usually we don’t use these events in our code and use just Page_Load event where the Viewstate value already got loaded. But as in Init phase, we cannot access our latest entered values in textbox, so in Init you won’t be able to get the latest changes. So I can say in Init we won’t be able to get the postback value.
Init is called when you can initialize your page controls, this is the place that comes into picture after each Control initialization, till this event they get their Unique Id, master page etc. In Init you cannot access any controls properties after the last viewstate, I mean suppose you enter some text in a textbox control and click on a button control that makes a postback, now you want to view the value latest entered. In such case you will be able to see the textbox value which you’ve entered after the round trip happens, this is because of ViewState property of controls. That means they preserved your last saved value, but you see this value after Init phase because, usually we don’t use these events in our code and use just Page_Load event where the Viewstate value already got loaded. But as in Init phase, we cannot access our latest entered values in textbox, so in Init you won’t be able to get the latest changes. So I can say in Init we won’t be able to get the postback value.
InitComplete
In this event, Viewstate
functionality is turned on for server control. Viewstate of controls allows
preserving their values across postback.
PreLoad
This is the first event where
viewstate functionality starts retrieving their values. PreLoad executes after
InitComplete method. In this method, page has loaded values from viewstate. So
for example in a button click event if you create a viewstate like below than
what will going to be happen:
protected void btnSubmit_Click(object sender, EventArgs e)
{
ViewState["myData"] = "just a text string";
}
After button click, postback
will happen at it will start calling page events like PreInit, Init,
Initcomplete. Till these three events you will not be able to get the value of
Viewstate “myData”. Even when the event fires PreLoad event of page, at this
time you cannot access the ViewState, this is because ViewState will set the
value when asp.net reaches the ButtonClick event, and this will happen after
Load event, so one more time we will click on our submit button, and because
now the ViewState[“myData”] resides into my page, I can access it on my PreLoad
event. For better understanding please see the screen shot below:
Load
Most of the developers are
familiar with the page load, as this is the only event that comes by default in
aspx.cs page when you start doing anything with your code behind. The page Load
events executes after the Page_PreLoad event. If you have created your own Load
method in constructor of your code behing, then this will be the method that
will execute before the Page_Load event and after Page_PreLoad event, for
better understanding refer to the image below:
As you are seeing in above
code, I’ve created my own Page_Load event in my code behind as well as the
default Load event, I didn’t mention Page_PreLoad event here, but it will
execute after Page_InitComplete event. So back to the image, the _Default_Load
will execute first before the Page_Load event. If you have any master page in
your page, then the Load event of your master page will run followed by the
user control Load event if they exist in your file.
Events
After the Page_load the next
event is Page Control’s event. For example, if you have a control that raises
postback just like button, and you clicked on the Button, so after Page_Load
your Button_Click event will fire, and do the rest of the thing you’ve
mentioned in your page. for better understanding please refer to the image
below, event execution will be happen in that sequence how image is showing, in
event portion whatever you will do that will go ahead and will do the things
you’ve mentioned in you page. just like below, I said to create a
ViewState[“myData”] and put some string inside that viewstate. So now the
viewstate is ready to preserve ahead in my code.
In Events you can also check
the Page.IsValid property if you’ve used any validator controls in your page
like regularexpressionValidator, requiredFieldValidator, Range etc. To check
this property refer to the image below.
LoadComplete
This event can be used when all
the event processing has been done in the page.
PreRender/PreRenderComplete
PreRender event gets called when page has created all the controls that user will see in his browser. PreRenderComplete is the last place to change anything in the page. After this event any changes will not get preserved in page cycle.
PreRender event gets called when page has created all the controls that user will see in his browser. PreRenderComplete is the last place to change anything in the page. After this event any changes will not get preserved in page cycle.
SaveStateComplete
event gets fired immediately
after the PreRenderComplete event, in this event the viewstate functionality
and control state get saved, as I said in PreRenderComplete changes can be done
that will affect the next postback. In SaveStateComplete you can do the changes
in your server control, but the state won’t be available in next postbacks.
Render
Render is not an event but this is the phase where the HTML of your page will get rendered to the output stream with the help of HTMLTextWriter. You can override the Render method of page if you want to write your own code rather than the actual HTML text. As like below:
Render is not an event but this is the phase where the HTML of your page will get rendered to the output stream with the help of HTMLTextWriter. You can override the Render method of page if you want to write your own code rather than the actual HTML text. As like below:
As you can see in the code
above, I’ve override the Render method in my code and write something with
Heading 1 tag and later on called the base.render method. In current scenario
the thing will happen is: apart my server controls code in my browser I’ll be able
to see my Hello world text also. If I remove the base.render method calls, than
I won’t be able to view my any control if I’ve created in page.
Unload
This is the last event that gets fired. This is the page cleaning process like closing the open file connections etc, so in this process you cannot do any kind of manipulation with data that affect the rendering, you are restricted to use Response property also, and doing such you will get an exception message.
This is the last event that gets fired. This is the page cleaning process like closing the open file connections etc, so in this process you cannot do any kind of manipulation with data that affect the rendering, you are restricted to use Response property also, and doing such you will get an exception message.
Seq | Events | Controls Initialized | View state Available |
Form data Available |
What Logic can be written here? |
1 | Init | No | No | No | Note: You can access form data etc. by using ASP.NET request objects but not by Server controls.Creating controls dynamically, in case you have controls to be created on runtime. Any setting initialization.Master pages and them settings. In this section, we do not have access to viewstate , posted values and neither the controls are initialized. |
2 | Load view state | Not guaranteed | Yes | Not guaranteed | You can access view state and any synch logic where you want viewstate to be pushed to behind code variables can be done here. |
3 | PostBackdata | Not guaranteed | Yes | Yes | You can access form data. Any logic where you want the form data to be pushed to behind code variables can be done here. |
4 | Load | Yes | Yes | Yes | This is the place where you will put any logic you want to operate on the controls. Like flourishing a combobox from the database, sorting data on a grid, etc. In this event, we get access to all controls, viewstate and their posted values. |
5 | Validate | Yes | Yes | Yes | If your page has validators or you want to execute validation for your page, this is the right place to the same. |
6 | Event | Yes | Yes | Yes | If this is a post back by a button click or a dropdown change, then the relative events will be fired. Any kind of logic which is related to that event can be executed here. |
7 | Pre-render | Yes | Yes | Yes | If you want to make final changes to the UI objects like changing tree structure or property values, before these controls are saved in to view state. |
8 | Save view state | Yes | Yes | Yes | Once all changes to server controls are done, this event can be an opportunity to save control data in to view state. |
9 | Render | Yes | Yes | Yes | If you want to add some custom HTML to the output this is the place you can. |
10 | Unload | Yes | Yes | Yes | Any kind of clean up you would like to do here. |
Thanks for sharing with us.Great post
ReplyDeleteDot Net Training in Chennai