技术开发 频道

Windows Vista艰难的销售之路



三、Triggers属性
 
ASP.NET AJAX中UpdatePanel有个比较重要的属性 Triggers,它有两个值分别为AsyncPostBackTrigger和PostBackTrigger。AsyncPostBackTrigge用来指定某个服务器端控件以及其将触发的服务器端事件,作为该UpdatePanel异步更新的触发器,它需要设置的属性有控件ID和服务端控件的事件;PostBackTrigger用来指定在UpdatePanel中的某个服务端控件,它所引发的回送不使用异步回送,而仍然是传统的回送,换句话说就是,用提交表单的形式来交互。

我们用一个嵌套UpdatePanel的例子,来说明这个问题比较直观。这个例子会使用到UpdateMode和Triggers两个属性。我们先看代码,在后面我们再来分析区别。


Aspx页面代码:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="UpdatePanel_2.aspx.cs" Inherits="Updatepanel_UpdatePanel_2" %>
 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>无标题页</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:ScriptManager ID="ScriptManager1" runat="server">
        </asp:ScriptManager>
   
    </div>
        <asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Conditional">
            <ContentTemplate>
                <asp:Label ID="Label1" runat="server" Text="Label"></asp:Label>
                <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text=" BtnParent" />
                <asp:UpdatePanel ID="UpdatePanel2" runat="server" UpdateMode="Conditional">
                    <ContentTemplate>
                        <asp:Label ID="Label2" runat="server" Text="Label"></asp:Label>
                        <asp:Button ID="Button2" runat="server" OnClick="Button2_Click" Text=" BtnChild" />
                    </ContentTemplate>
                    <Triggers>
                        <asp:AsyncPostBackTrigger ControlID="Button2" EventName="Click" />
                    </Triggers>
                </asp:UpdatePanel>
            </ContentTemplate>
        </asp:UpdatePanel>
    </form>
</body>
</html>


     CodeBehind代码:

using System; using System.Data; using System.Configuration; using System.Collections; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; public partial class Updatepanel_UpdatePanel_2 : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { Label1.Text = DateTime.Now.ToString(); Label2.Text = DateTime.Now.ToString(); } protected void Button1_Click(object sender, EventArgs e) { Label1.Text = DateTime.Now.ToString(); } protected void Button2_Click(object sender, EventArgs e) { Label2.Text = DateTime.Now.ToString(); } }
当点击BtnParent时,两个UpdatePanel中Label显示的时间都更新了。而点击BtnChild时,只有内层的UpdatePanel中Label显示的时间更新了。这个示例的效果,就是UpdateMode和Triggers两个属性设置的关系了。当UpdateMode设置为Conditional时,这时设置Triggers属性就有用了。我们可以看到,内层的UpdatePanel中,多了三行Triggers的代码:
 
<Triggers>
         <asp:AsyncPostBackTrigger ControlID="Button2" EventName="Click" />
 </Triggers>
 
这段代码的意思是:我们采用AsyncPostBackTrigger的方式来交互,而触发的是Button2也就是BtnChild,触发的事件为Click。
 
这样我们可以使用这两个属性,让一个Web页面中,同时存在多个UpdatePanel。并且,UpdatePanel可以相互嵌套了。
 
四、UpdatePanel使用总结
 
只要放置在UpdatePanel中的控件,使用者就可以使用异步更新这些控件中的数据。包括数据控件,也是没有问题的。比如:DataView的分页,DateDetail中的更新、删除等等。你可以任意放置你的UpdatePanel,来实现异步更新,来制作没有“屏闪”的Web程序。
 
0
相关文章