1. 在ASP.NET 2.0中,一个ASP.NET页面的生命周期主要为: 
  2. 客户端请求页面 
  3. 预初始化(OnPreInit) 
  4. 初始化(OnInit) 
  5. 完成初始化(OnInitComplete) 
  6. 载入ViewState(LoadViewState) 
  7. 处理回送数据(IPostBackDataHandler) 
  8. Page_OnPreLoad—》Page_OnLoad 
  9. 回发更改通知(RaisePostDataChangedEvent) 
  10. 处理回发事件(RaisePostBackEvent) 
  11. Page_OnLoadComplete 
  12. 预呈现(OnPreRender) 
  13. 完成预呈现(OnPreRenderComplete) 
  14. 保存ControlState(SaveControlState) 
  15. 保存ViewState(SaveViewState) 
  16. 呈现(Render) 
  17. Page_UnLoad。  
  18.  
  19. OnPreInit:在初始化页面OnInit事件前触发。在这个阶段里,可以进行定义站点主题(Theme)或加载站点个性化所需要的数据信息等操作。  
  20. OnInitComplete:完成初始化页面OnInit事件后触发。  
  21. OnPreLoad:在加载页面OnLoad事件前触发。  
  22. OnLoadComplete:完成页面加载OnLoad事件后触发。  
  23. OnPreRenderComplete:在完成预呈现OnPreRender事件后触发。这是完成页面呈现的最后一道关卡,在此之后,页面将无法再进行任何呈现上的改动。  
  24. SaveControlState:保存控件状态ControlState。ControlState是ASP.NET2.0控件新增的一个属性,类似ViewState作用,但它们区别在于ControlState用于保存更加重要的控件状态信息,以保证在禁用ViewState的情况下还可以对控件状态进行读写操作。  
  25. 增加对页面Header的控制:  
  26. System.Web.UI.Page类新增加了Header属性,用于对HTML页面头区域里数据的操作。通过对Header属性的跟踪,可以发现,Header属性保存着一个实现IPageHeader接口的对象(该对象有LinkedStyleSheets、Metadata、StyleSheet和Title四个属性),实际上正是通过这个对象实现对HTML页面头区域里数据的操作的。 
  27. 例如:  
  28. <script runat="server">  
  29. void Page_Load(object sender, System.EventArgs e)  
  30. {  
  31. this.Header.Metadata.Add("author""brooks");  
  32. }  
  33. </script> 
  34. 其运行结果为:  
  35. <html>  
  36. <head> <title>Untitled Page</title>  
  37. <meta name="author" content="brooks" />  
  38. </head>  
  39. 定义表单中的默认按钮:  
  40. 在ASP.NET1.0中,我就为了设置表单中的默认按钮而一筹莫展。幸好ASP.NET2.0把这个功能补上了,现在可以非常方便的设置表单中的默认按钮了。  
  41. <%@ page language="C#" %>  
  42. <script runat="server">  
  43. void Button1_Click(object sender, System.EventArgs e)  
  44. {  
  45. this.LB_Message.Text = "You clicked button1";  
  46. }  
  47. </script>  
  48. <html>  
  49. <head runat="server">  
  50. <title>Untitled Page</title>  
  51. </head>  
  52. <body>  
  53. <form runat="server" defaultbutton="Button1">  
  54. <asp:textbox id="Textbox1" runat="server"></asp:textbox>  
  55. <asp:button id="Button1" runat="server" text="Button" onclick="Button1_Click" />  
  56. <asp:label id="LB_Message" runat="server"></asp:label>  
  57. </form>  
  58. </body>  
  59. </html>  
  60. 设置焦点:  
  61. 现在假设为TextBox1控件设置焦点,在ASP.NET 2.0中可以这样实现:  
  62. this.Textbox1.Focus(); 或 this.SetFocus(this.Textbox1); 即可为TextBox1控件设置焦点。  
  63. 如果打算也为表单设置个默认焦点控件,让光标默认停留在TextBox1上:  
  64. <form runat="server" defaultfocus="TextBox1">  
  65. 跨页面数据发送:  
  66. 如果你需要多个页面发送数据到同一个表单程序进行处理,或者数据在多个页面之间传输处理的话,你就可以使用ASP.NET 2.0这个新特性。例如,我打算把Default.aspx页里TextBox1里的文本数据发送到Default2.aspx页面进行处理:  
  67. Default.aspx页:  
  68. <%@ Page Language="C#" %>  
  69. <script runat="server">  
  70. void Button2_Click(object sender, EventArgs e)  
  71. {  
  72. Label1.Text = "Hi," + TextBox1.Text + ". This is Default.aspx";  
  73. }  
  74. </script> 
  75. <html xmlns="http://www.w3.org/1999/xhtml" >  
  76. <head runat="server">  
  77. <title>Untitled Page</title>  
  78. </head>  
  79. <body>  
  80. <form id="form1" runat="server">  
  81. <asp:TextBox ID="TextBox1" Runat="server"></asp:TextBox>  
  82. <asp:Button ID="Button1" Runat="server" Text="PostToAnotherPage" PostBackUrl="~/Default2.aspx" />  
  83. <asp:Button ID="Button2" Runat="server" Text="PostToSelf" OnClick="Button2_Click" />  
  84. <br />  
  85. <asp:Label ID="Label1" Runat="server" Text="Label"></asp:Label>  
  86. </form>  
  87. </body>  
  88. </html>  
  89. Default2.aspx页:  
  90. <%@ Page Language="C#" %>  
  91. <script runat="server">  
  92. void Page_Load(object sender, System.EventArgs e)  
  93. {  
  94. TextBox textBox1 = (TextBox)PreviousPage.FindControl("TextBox1");  
  95. this.Label1.Text = "Hi," + textBox1.Text + ". This is Default2.aspx!";  
  96. }  
  97. </script>  
  98. <html xmlns="http://www.w3.org/1999/xhtml" >  
  99. <head runat="server">  
  100. <title>Untitled Page</title>  
  101. </head>  
  102. <body>  
  103. <form id="form1" runat="server">  
  104. <asp:label id="Label1" runat="server"></asp:label>  
  105. </form>  
  106. </body>  
  107. </html>