国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

ASP.NET 2.0頁面框架的幾處變化

瀏覽:238日期: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
相關文章:
主站蜘蛛池模板: 国产在线视频专区 | 亚洲国产天堂久久综合网站 | 亚洲第5页| 国产一区二区三区日韩 | 97青娱国产盛宴精品视频 | 成年女人免费视频播放成年m | 国产精品一级香蕉一区 | 精品中文字幕不卡在线视频 | 久久亚洲综合中文字幕 | 中文字幕一区视频一线 | 国产一区亚洲 | 手机在线观看亚洲国产精品 | 97国产在线视频 | 日本一区二区高清不卡 | 99免费在线播放99久久免费 | 亚洲精品一区二区三区在线播放 | 国内自拍一区 | 久久国产欧美日韩精品 | 欧美三级网站 | 夜色www国产精品资源站 | 国产精品久久久久久久久久影院 | 久久免费激情视频 | 高清一本之道加勒比在线 | 在线观看一区二区三区四区 | 欧美日本在线三级视频 | 国产在线精品一区二区 | 国产精品亚洲二区在线 | 秘书高跟黑色丝袜国产91在线 | 午夜影院美女 | 国产成人理在线观看视频 | 国产精品亚洲一区在线播放 | 久久久免费观成人影院 | 神马国产| 国产精品成人免费视频 | 亚洲视频在线观看免费视频 | 国产三级a三级三级三级 | 一级美女视频 | 国产精品久久久久久久网站 | 九九干 | 欧美日韩一区二区三区免费不卡 | 日本人成在线视频免费播放 |