色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

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

瀏覽:246日期: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
相關文章:
主站蜘蛛池模板: 欧美一级毛片免费播放器 | 美国毛片亚洲社区在线观看 | 成人在线亚洲 | 久久久在线视频精品免费观看 | 欧美国产日韩一区二区三区 | 男女扒开双腿猛进入爽爽视频 | 在线观看免费视频国产 | 亚洲高清视频在线观看 | 亚洲成人一区在线 | 国产日韩欧美一区二区 | 成人午夜在线观看国产 | 欧美精品久久久久久久免费观看 | 台湾三级在线播放 | 91精品国产乱码久久久久久 | a级国产乱理伦片在线观看 a级国产乱理伦片在线观看99 | 国产91第一页 | 一区二区三区免费精品视频 | 在线视频观看免费视频18 | a视频免费| 欧美 在线 成 人怡红院 | 免费国产午夜高清在线视频 | 日韩精品小视频 | 美女被免费网站在线视频软件 | 亚洲精品一区二区三区第四页 | 欧美ppp | 亚洲欧美激情视频 | 国产精品久久久久久福利漫画 | 一级特黄一欧美俄罗斯毛片 | 亚洲欧美精选 | 久久精品国产精品亚洲综合 | 天堂一区二区三区在线观看 | 美女把张开腿男生猛戳免费视频 | 国产一级片网址 | 男操女免费视频 | 曰批美女免费视频播放 | 亚洲影院在线 | 国产精品三级在线播放 | 91精品日本久久久久久牛牛 | 91精品国产爱久久久久 | 深夜福利爽爽爽动态图 | 国产成人a在一区线观看高清 |