亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

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
相關文章:
主站蜘蛛池模板: 国产主播在线观看 | a大片久久爱一级 | 性潮高免费视频免费看 | 成人黄色免费观看 | 色综合精品 | 欧美一级久久久久久久大 | 一级成人毛片免费观看 | 色永久| 2048国产精品原创综合在线 | 国产成人亚洲精品77 | 成人淫片免费视频95视频 | 天天综合网天天综合色 | 免费国产黄网站在线观看视频 | 一区二区三区视频在线播放 | 久久日本精品99久久久 | 91日本| 99久久精品免费国产一区二区三区 | 尤物视频在线播放 | 在线观看一区二区三区四区 | 亚洲精品在线观看91 | 亚洲协和影视 | 国产精品偷伦视频免费手机播放 | 国产日本亚洲欧美 | 中文字幕亚洲第一 | 视频一区二区三区自拍 | 国产日韩线路一线路二 | 美女黄18岁以下禁看 | 国产v片免费播放 | 黄色免费网站在线播放 | 国产成人a大片大片在线播放 | 亚洲精品成人一区 | 国产在线观看黄色 | 亚洲欧美日韩不卡一区二区三区 | 欧美日韩你懂的 | 亚洲国产高清在线 | 日韩在线高清 | 国产成本人三级在线观看网站 | 爱爱网网站免费观看 | 青青草在线视频免费观看 | 日韩毛片欧美一级a网站 | 欧美性三三影院 |