首页
技术库|站长工具|技术手册|字体库|知识点词汇表| 联系我们|
打开本页的html静态页面
 

主菜单

文章分类

.: .Net技术 .: .Net分析与设计 .: ASP.NET的5个ajax控件(转)

  • 全文内容
  • 发表评论
  • 文章点评
  • 文章附件
  • Email文章
  • 打印文章

ASP.NET的5个ajax控件(转)

点击次数:554 创建日期:2-26-2008 录入:cn-web.com 字体:[ ] 点评:


作者:webabcd rn


本文介绍了ASP.NET 的5个AJAX控件,分别是ScriptManager、ScriptManagerProxy、UpdatePanel、UpdateProgress和Timer。
 
 
1、ScriptManager控件和ScriptManagerProxy控件
    ·一个页只能有一个ScriptManager(包含了所有脚本资源),要放到任何用到AJAX的控件的前面。
    ·如果把它放到母版页,而内容页需要与其不同的配置的话,则应在内容页使用ScriptManagerProxy。
    ·ScriptManager默认EnablePartialRendering="true"。
    ·ScriptManager的 AllowCustomErrorsRedirect="true"的时候,出现异常就会转到web.config里customErrors中
 
defaultRedirect所指的地址。
 
示例代码
 
<%@ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="Sample.aspx.cs"
    Inherits="Overview_Sample" Title="最简单的示例cn-web.com" %>
<asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
    <ul>
        <li>之前要有ScriptManager(包含了所有脚本资源),我把它放到母版页了。内容页如需不同配置则应使用ScriptManagerProxy。</li>
        <li>最简单的示例,拖个UpdatePanel进来。在 UpdatePanel内拖个GridView,并设置其数据源即可。 </li>
    </ul>
    <asp:UpdatePanel ID="UpdatePanel1" runat="server">
        <ContentTemplate>
            <asp:GridView ID="GridView1" runat="server" AllowPaging="True" AllowSorting="True"
                DataSourceID ="SqlDataSource1">
                <Columns>
                   & nbsp;<asp:CommandField ShowEditButton="True" ShowSelectButton="True" />
                </Columns>
            </asp:GridView>
        </ContentTemplate>
    </asp:UpdatePanel>
    <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<% $ ConnectionStrings:connstr %>"
        DeleteCommand="DELETE FROM [Products] WHERE [ProductID] = @ProductID" InsertCommand="INSERT INTO [Products]  ([ProductName], [QuantityPerUnit], [UnitPrice], [Discontinued]) VALUES  (@ProductName, @QuantityPerUnit, @UnitPrice, @Discontinued)"
        SelectCommand="SELECT  [ProductID], [ProductName], [QuantityPerUnit], [UnitPrice], [Discontinued] FROM  [Products]"
        UpdateCommand="UPDATE  [Products] SET [ProductName] = @ProductName, [QuantityPerUnit] = @QuantityPerUnit,  [UnitPrice] = @UnitPrice, [Discontinued] = @Discontinued WHERE [ProductID]  = @ProductID">
        <DeleteParameters>
            <asp:Parameter Name="ProductID" Type="Int32" />
        </DeleteParameters>
        <UpdateParameters>
            <asp:Parameter Name="ProductName" Type="String" />
            <asp:Parameter Name="QuantityPerUnit" Type="String" />
            <asp:Parameter Name="UnitPrice" Type="Decimal" />
            <asp:Parameter Name="Discontinued" Type="Boolean" />
            <asp:Parameter Name="ProductID" Type="Int32" />
        </UpdateParameters>
        <InsertParameters>
            <asp:Parameter Name="ProductName" Type="String" />
            <asp:Parameter Name="QuantityPerUnit" Type="String" />
            <asp:Parameter Name="UnitPrice" Type="Decimal" />
            <asp:Parameter Name="Discontinued" Type="Boolean" />
        </InsertParameters>
    </asp:SqlDataSource>
</asp:Content>
 
2、 UpdatePanel控件
    ·UpdatePanel内放置需要被刷新的控件,如果是其内部控件事件导致其刷新,则不用另外做什么设置,因为UpdatePanel默认ChildrenAsTriggers="true"。
    ·如果是UpdatePanel外部控件导致其刷新的话,则应设置 Triggers。
    ·在Triggers内,如果AsyncPostBackTrigger未设置EventName,则为其指定控件的默认事件。
    ·UpdatePanel默认UpdateMode="Always",需要的话应设置UpdateMode="Conditional"。
    ·RenderMode="Block"对应div;RenderMode="Inline"对应span
 
示例代码
 
<%@ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="UpdatePanel.aspx.cs"
    Inherits="Overview_UpdatePanel" Title="UpdatePanel" %>
<asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
    <ul>
        <li>UpdatePanel内放置需要被刷新的控件,如果是其内部控件事件导致其刷新,则不用另外做什么设置,因为UpdatePanel默认ChildrenAsTriggers="true"。</li>
        <li>如果是UpdatePanel外部控件导致其刷新的话,则应设置Triggers。</li>
        <li>在Triggers内,如果AsyncPostBackTrigger 未设置EventName,则为其指定控件的默认事件。</li>
        <li>UpdatePanel默认UpdateMode="Always",需要的话应设置UpdateMode="Conditional"。</li>
        <li>RenderMode="Block"对应div; RenderMode="Inline"对应span</li>
    </ul>
    <asp:UpdatePanel ID="UpdatePanel1" runat="server">
        <contenttemplate>
            <fieldset>
                <legend>我在UpdatePanel里</legend>
                <asp:Label ID="Label1" runat="server" Text="我是 Label"></asp:Label>
            </fieldset>
        </contenttemplate>
        <triggers>
            <%--如果没设置 EventName,则取默认事件,Button的默认事件为Click-- %>
            <asp:AsyncPostBackTrigger ControlID="Button1" />
        </triggers>
    </asp:UpdatePanel>
    <p>
        &nbsp;</p>
    <fieldset>
        <legend>我在UpdatePanel外</legend>
        <asp:Button ID="Button1" runat="server" Text="按钮" OnClick="Button1_Click" />
    </fieldset>
    <p>
        &nbsp;</p>
    <%--嵌套UpdatePanel-- %>
    <asp:UpdatePanel ID="UpdatePanel2" runat="server" UpdateMode="Conditional">
        <contenttemplate>
            <fieldset>
                <legend>外围UpdatePanel</legend>
                <asp:Label ID="Label2" runat="server" Text="我是 Label"></asp:Label>
                <asp:Button ID="Button2" runat="server" Text="按钮" OnClick="Button2_Click" />
                <asp:UpdatePanel ID="UpdatePanel3" runat="server">
                   & nbsp;<ContentTemplate>
                   & nbsp;    <fieldset>
                   & nbsp;        <legend>嵌套UpdatePanel</legend>
                   & nbsp;        <asp:Label ID="Label3" runat="server" Text="我是Label"></asp:Label>
                   & nbsp;        <asp:Button ID="Button3" runat="server" Text="按钮" OnClick="Button3_Click" />
                   & nbsp;    </fieldset>
                   & nbsp;</ContentTemplate>
                </asp:UpdatePanel>
            </fieldset>
        </contenttemplate>
    </asp:UpdatePanel>
</asp:Content>

 
 
3、UpdateProgress控件
    ·默认,任何回发,当有延迟的时候则显示UpdateProgress里的ProgressTemplate。
    ·要与某UpdatePanel关联则设置 AssociatedUpdatePanelID属性。
    ·DynamicLayout为true则用“display:none;”隐藏;DynamicLayout为false则用 “visibility:hidden;”隐藏。
    ·默认情况下,例如有2个异步回发,如果第1个还没有执行完毕就执行第2个的话,则会先取消第1个异步回发。
 
示例代码
 
<%@ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="UpdateProgress.aspx.cs"
    Inherits="Overview_UpdateProgress" Title="UpdateProgress" %>
<asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
    <ul>
        <li>默认,任何回发,当有延迟的时候则显示 UpdateProgress里的ProgressTemplate。</li>
        <li>要与某UpdatePanel关联则设置 AssociatedUpdatePanelID属性。</li>
        <li>DynamicLayout为true则用“display:none; ”隐藏;DynamicLayout为false则用“visibility:hidden;”隐藏。</li>
        <li>默认情况下,例如有2个异步回发,如果第1 个还没有执行完毕就执行第2个的话,则会先取消第1个异步回发。</li>
    </ul>
    <asp:UpdatePanel ID="UpdatePanel1" runat="server">
        <ContentTemplate>
            <fieldset>
                <legend>UpdatePanel1</legend>
                <asp:Label ID="Label1" runat="server" Text="Label1"></asp:Label>
                <br />
                <asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_Click" />
            </fieldset>
        </ContentTemplate>
    </asp:UpdatePanel>
    <asp:UpdateProgress ID="UpdateProgress1" runat="server" AssociatedUpdatePanelID="UpdatePanel1"
        DynamicLayout="false">
        <ProgressTemplate>
            <p>
                UpdatePanel1更新中
            </p>
        </ProgressTemplate>
    </asp:UpdateProgress>
    <p>
        &nbsp;</p>
    <asp:UpdatePanel ID="UpdatePanel2" runat="server">
        <ContentTemplate>
            <fieldset>
                <legend>UpdatePanel2</legend>
                <asp:Label ID="Label2" runat="server" Text="Label2"></asp:Label>
                <br />
                <asp:Button ID="Button2" runat="server" Text="Button" OnClick="Button2_Click" />
            </fieldset>
        </ContentTemplate>
    </asp:UpdatePanel>
    <asp:UpdateProgress ID="UpdateProgress2" runat="server" AssociatedUpdatePanelID="UpdatePanel2"
        DynamicLayout="true">
        <ProgressTemplate>
            <p>
                UpdatePanel2更新中
            </p>
        </ProgressTemplate>
    </asp:UpdateProgress>
    <p>
        &nbsp;</p>
    <asp:UpdatePanel ID="UpdatePanel3" runat="server">
        <ContentTemplate>
            <fieldset>
                <legend>UpdatePanel3</legend>
                <asp:Label ID="Label3" runat="server" Text="Label3"></asp:Label><br />
                <asp:Button ID="Button3" runat="server" Text="Button" OnClick="Button3_Click" />
            </fieldset>
        </ContentTemplate>
    </asp:UpdatePanel>
    <asp:UpdateProgress ID="UpdateProgress3" runat="server">
        <ProgressTemplate>
            有延迟我就更新
        </ProgressTemplate>
    </asp:UpdateProgress>
</asp:Content>

 
 
4、Timer控件
    ·Interval:间隔时间,单位(毫秒);每一个间隔时间后将触发 Tick事件。
    ·Timer要放在其所刷新的UpdatePanel内部;放外面的话要设置UpdatePanel的Triggers。
 
示例代码
 
<%@ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="Timer.aspx.cs"
    Inherits="Overview_Timer" Title="Timer" %>
<asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
    <ul>
        <li>Interval:间隔时间,单位(毫秒);每一个间隔时间后将触发Tick事件 </li>
        <li>Timer要放在其所刷新的UpdatePanel内部;放外面的话要设置UpdatePanel的Triggers。</li>
    </ul>
    <asp:UpdatePanel ID="UpdatePanel1" runat="server">
        <ContentTemplate>
            <fieldset>
                <legend>UpdatePanel1</legend>
                <p>
                   & nbsp;内部Timer
                   & nbsp;<asp:Timer ID="Timer1" runat="server" OnTick="Timer1_Tick" Interval="1000">
                   & nbsp;</asp:Timer>
                </p>
                <asp:Label ID="Label1" runat="server" Text="Label"></asp:Label>
            </fieldset>
        </ContentTemplate>
    </asp:UpdatePanel>
</asp:Content>

 
 注:以上示例涉及到后置代码的,其作用都是用来刷新相关的Label的,所以略掉了。

请文明参与讨论,禁止漫骂攻击。
评论总数:0 [ 查看全部 ] 网友评论
此文章还没有任何评论!
(+5分)
(+4分)
(+3分)
(+2分)
(+1分)
此内容无附件
网站地图 - 知识词汇 - 全文检索 - 广告服务 - 帮助中心 - 联系我们
.:www.cn-web.com
网站技术开发联盟之WEB开发技术知识库
联系人:老韩(QQ:5679551)
晋ICP备07003487号