- 本文介紹ASP.NET調用UpdatePanel的Update()方法,使用ScriptManager的RegisterAsyncPostBackControl()註冊Button1爲一個異步提交控件。
ASP.NET中用編程的方法控制UpdatePanel的更新
UpdatePanel可以用來創建豐富的局部更新Web應用程序,它是ASP.NET 2.0 AJAX Extensions中很重要的一個控件。對於UpdatePanel,我們也可以使用編程的方法來控制它的更新,可以通過ScriptManager的RegisterAsyncPostBackControl()方法註冊一個異步提交的控件,並且調用UpdatePanel的Update()方法來讓它更新。再次用我在前面的文章中用到的一個無聊的時間更新例子來看一下,有時候我覺得例子過於複雜更加不好說明白所要講的內容,如下代碼所示,注意Button1並不包含在UpdatePanel中:
- <%@PageLanguage="C#"AutoEventWireup="true"CodeFile="Default
.aspx.cs"Inherits="_Default"%> - <scriptrunatscriptrunat="server">
- voidButton1_Click(objectsender,EventArgse)
- {
- this.Label2.Text=DateTime.Now.ToString();
- }
- script>
- <htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml">
- <headrunatheadrunat="server">
- <title>RefreshinganUpdatePanelProgrammaticallytitle>
- head>
- <body>
- <formidformid="form1"runat="server">
- <asp:ScriptManagerIDasp:ScriptManagerID="ScriptManager1
"runat="server"/> - <div>
- <asp:UpdatePanelIDasp:UpdatePanelID="UpdatePanel1"runat=
"server"UpdateMode="Conditional"> - <ContentTemplate>
- <asp:LabelIDasp:LabelID="Label1"runat="server"Text=
"更新時間:">asp:Label> - <asp:LabelIDasp:LabelID="Label2"runat="server"Text=
"Label"ForeColor="Red">asp:Label><br/><br/> - ContentTemplate>
- asp:UpdatePanel>
- <asp:ButtonIDasp:ButtonID="Button1"runat="server"Text=
"Button"OnClick="Button1_Click"/> - div>
- form>
- body>
- html>
再次修改上面的例子,使用ScriptManager的RegisterAsyncPostBackControl()註冊Button1爲一個異步提交控件,並且調用UpdatePanel的Update()方法:
- <%@PageLanguage="C#"AutoEventWireup="true"CodeFile="Default.aspx.cs"
Inherits="_Default"%> - <scriptrunatscriptrunat="server">
- voidPage_Load(objectsender,EventArgse)
- {
- ScriptManager1.RegisterAsyncPostBackControl(Button1);
- }
- voidButton1_Click(objectsender,EventArgse)
- {
- this.Label2.Text=DateTime.Now.ToString();
- this.UpdatePanel1.Update();
- }
- script>
- <htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml">
- <headrunatheadrunat="server">
- <title>RefreshinganUpdatePanelProgrammaticallytitle>
- head>
- <body>
- <formidformid="form1"runat="server">
- <asp:ScriptManagerIDasp:ScriptManagerID="ScriptManager1"runat="server"/>
- <div>
- <asp:UpdatePanelIDasp:UpdatePanelID="UpdatePanel1"runat=
"server"UpdateMode="Conditional"> - <ContentTemplate>
- <asp:LabelIDasp:LabelID="Label1"runat="server"Text="更新時間:">asp:Label>
- <asp:LabelIDasp:LabelID="Label2"runat="server"Text="Label"ForeColor
="Red">asp:Label><br/><br/> - ContentTemplate>
- asp:UpdatePanel>
- <asp:ButtonIDasp:ButtonID="Button1"runat="server"Text=
"Button"OnClick="Button1_Click"/> - div>
- form>
- body>
- html>
以上是ASP.NET調用UpdatePanel的Update()方法
常見錯誤:
當對UserControl進行繼承的時候,編譯容易出現報錯:“找不到父類的UserControl",此時只要將父類的UserControl做一個改動,編譯器就能重新找到它並編譯了!
更新UpdatePanel 控件
UpdatePanel.Update();