文章詳情頁
ASP.NET 2.0頁面框架的幾處變化
瀏覽:227日期:2022-06-03 13:47:10
新增的頁面事件:
在ASP.NET 2.0中,一個ASP.NET頁面的生命周期主要為(紅色字體表示ASP.NET 2.0新增加的階段頁面事件):客戶端請求頁面—》預初始化(OnPreInit)—》初始化(OnInit)—》完成初始化(OnInitComplete)—》載入ViewState(LoadViewState)—》處理回送數據(IPostBackDataHandler)—》Page_OnPreLoad—》Page_OnLoad—》回發更改通知(RaisePostDataChangedEvent)—》處理回發事件(RaisePostBackEvent)—》Page_OnLoadComplete—》預呈現(OnPreRender)—》完成預呈現(OnPreRenderComplete)—》保存ControlState(SaveControlState)—》保存ViewState(SaveViewState)—》呈現(Render)—》Page_UnLoad。
OnPreInit:在初始化頁面OnInit事件前觸發。在這個階段里,可以進行定義站點主題(Theme)或加載站點個性化所需要的數據信息等操作。
OnInitComplete:完成初始化頁面OnInit事件后觸發。
OnPreLoad:在加載頁面OnLoad事件前觸發。
OnLoadComplete:完成頁面加載OnLoad事件后觸發。
OnPreRenderComplete:在完成預呈現OnPreRender事件后觸發。這是完成頁面呈現的最后一道關卡,在此之后,頁面將無法再進行任何呈現上的改動。
SaveControlState:保存控件狀態ControlState。ControlState是ASP.NET2.0控件新增的一個屬性,類似ViewState作用,但它們區別在于ControlState用于保存更加重要的控件狀態信息,以保證在禁用ViewState的情況下還可以對控件狀態進行讀寫操作。
增加對頁面Header的控制:
System.Web.UI.Page類新增加了Header屬性,用于對HTML頁面頭區域里數據的操作。通過對Header屬性的跟蹤,可以發現,Header屬性保存著一個實現IPageHeader接口的對象(該對象有LinkedStyleSheets、Metadata、StyleSheet和Title四個屬性),實際上正是通過這個對象實現對HTML頁面頭區域里數據的操作的。例如:
<script runat="server">
void Page_Load(object sender, System.EventArgs e)
{
this.Header.Metadata.Add("author", "brooks");
}
</script>
其運行結果為:
<html>
<head> <title>Untitled Page</title>
<meta name="author" content="brooks" />
</head>
定義表單中的默認按鈕:
在ASP.NET1.0中,我就為了設置表單中的默認按鈕而一籌莫展。幸好ASP.NET2.0把這個功能補上了,現在可以非常方便的設置表單中的默認按鈕了。
<%@ page language="C#" %>
<script runat="server">
void Button1_Click(object sender, System.EventArgs e)
{
this.LB_Message.Text = "You clicked button1";
}
</script>
<html>
<head runat="server">
<title>Untitled Page</title>
</head>
<body>
<form runat="server" defaultbutton="Button1">
<asp:textbox id="Textbox1" runat="server"></asp:textbox>
<asp:button id="Button1" runat="server" text="Button" onclick="Button1_Click" />
<asp:label id="LB_Message" runat="server"></asp:label>
</form>
</body>
</html>
設置焦點:
現在假設為TextBox1控件設置焦點,在ASP.NET 2.0中可以這樣實現:
this.Textbox1.Focus(); 或 this.SetFocus(this.Textbox1); 即可為TextBox1控件設置焦點。
如果打算也為表單設置個默認焦點控件,讓光標默認停留在TextBox1上:
<form runat="server" defaultfocus="TextBox1">
跨頁面數據發送:
如果你需要多個頁面發送數據到同一個表單程序進行處理,或者數據在多個頁面之間傳輸處理的話,你就可以使用ASP.NET 2.0這個新特性。例如,我打算把Default.aspx頁里TextBox1里的文本數據發送到Default2.aspx頁面進行處理:
Default.aspx頁:
<%@ Page Language="C#" %>
<script runat="server">
void Button2_Click(object sender, EventArgs e)
{
Label1.Text = "Hi," + TextBox1.Text + ". This is Default.aspx";
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>Untitled Page</title>
</head>
<body>
<form id="form1" runat="server">
<asp:TextBox ID="TextBox1" Runat="server"></asp:TextBox>
<asp:Button ID="Button1" Runat="server" Text="PostToAnotherPage" PostBackUrl="~/Default2.aspx" />
<asp:Button ID="Button2" Runat="server" Text="PostToSelf" OnClick="Button2_Click" />
<br />
<asp:Label ID="Label1" Runat="server" Text="Label"></asp:Label>
</form>
</body>
</html>
Default2.aspx頁:
<%@ Page Language="C#" %>
<script runat="server">
void Page_Load(object sender, System.EventArgs e)
{
TextBox textBox1 = (TextBox)PreviousPage.FindControl("TextBox1");
this.Label1.Text = "Hi," + textBox1.Text + ". This is Default2.aspx!";
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>Untitled Page</title>
</head>
<body>
<form id="form1" runat="server">
<asp:label id="Label1" runat="server"></asp:label>
</form>
</body>
</html>
標簽:
XML/RSS
相關文章:
排行榜