利用Client端的Javascript來Cancel ASP.NET AJAX 非同步更新
最近在一本書上看到如何cancel正在做非同步更新的ajax
小弟以一個範例實作分享給大家呀....
c#範例..
環境:Visual Studio 2008 + .Net Framework 3.5
CancelUpdate.aspx
01 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="CancelUpdate.aspx.cs" Inherits="CancelUpdate" %>
02
03 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
04 <html xmlns="http://www.w3.org/1999/xhtml">
05 <head id="Head1" runat="server">
06 <title>CancelRefresh</title>
07 </head>
08 <body>
09 <form id="form1" runat="server">
10 <div>
11 <asp:ScriptManager ID="ScriptManager1" runat="server">
12 </asp:ScriptManager>
13 </div>
14 <asp:UpdatePanel ID="UpdatePanel1" runat="server">
15 <contenttemplate>
16 <asp:Button ID="Button1" runat="server" Text="Refresh"
17 onclick="Button1_Click" />
18 <br />
19 <asp:Label ID="Label1" runat="server" Text=""></asp:Label>
20 </contenttemplate>
21 <triggers>
22 <asp:AsyncPostBackTrigger ControlID="Button1" EventName="Click" />
23 </triggers>
24 </asp:UpdatePanel>
25 <asp:UpdateProgress ID="UpdateProgress1" runat="server" AssociatedUpdatePanelID="UpdatePanel1">
26 <progresstemplate>
27 Loading...<br />
28 <asp:Button ID="Button2" runat="server" Text="Cancel Refresh" OnClientClick="AbortPostBack(); return false;" />
29 </progresstemplate>
30 </asp:UpdateProgress>
31 </form>
32
33 <script type="text/javascript">
34
35 var prm = Sys.WebForms.PageRequestManager.getInstance();
36
37 function AbortPostBack()
38 {
39 if (prm.get_isInAsyncPostBack())
40 {
41 prm.abortPostBack();
42 }
43 }
44
45 </script>
46
47 </body>
48 </html>
49
02
03 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
04 <html xmlns="http://www.w3.org/1999/xhtml">
05 <head id="Head1" runat="server">
06 <title>CancelRefresh</title>
07 </head>
08 <body>
09 <form id="form1" runat="server">
10 <div>
11 <asp:ScriptManager ID="ScriptManager1" runat="server">
12 </asp:ScriptManager>
13 </div>
14 <asp:UpdatePanel ID="UpdatePanel1" runat="server">
15 <contenttemplate>
16 <asp:Button ID="Button1" runat="server" Text="Refresh"
17 onclick="Button1_Click" />
18 <br />
19 <asp:Label ID="Label1" runat="server" Text=""></asp:Label>
20 </contenttemplate>
21 <triggers>
22 <asp:AsyncPostBackTrigger ControlID="Button1" EventName="Click" />
23 </triggers>
24 </asp:UpdatePanel>
25 <asp:UpdateProgress ID="UpdateProgress1" runat="server" AssociatedUpdatePanelID="UpdatePanel1">
26 <progresstemplate>
27 Loading...<br />
28 <asp:Button ID="Button2" runat="server" Text="Cancel Refresh" OnClientClick="AbortPostBack(); return false;" />
29 </progresstemplate>
30 </asp:UpdateProgress>
31 </form>
32
33 <script type="text/javascript">
34
35 var prm = Sys.WebForms.PageRequestManager.getInstance();
36
37 function AbortPostBack()
38 {
39 if (prm.get_isInAsyncPostBack())
40 {
41 prm.abortPostBack();
42 }
43 }
44
45 </script>
46
47 </body>
48 </html>
49
CancelUpdate.aspx.cs
01
using System;
02
using System.Collections;
03
using System.Configuration;
04
using System.Data;
05
using System.Linq;
06
using System.Web;
07
using System.Web.Security;
08
using System.Web.UI;
09
using System.Web.UI.HtmlControls;
10
using System.Web.UI.WebControls;
11
using System.Web.UI.WebControls.WebParts;
12
using System.Xml.Linq;
13data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
14
public partial class CancelUpdate : System.Web.UI.Page
15
{
16
protected void Page_Load(object sender, EventArgs e)
17
{
18data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
19
}
20
protected void Button1_Click(object sender, EventArgs e)
21
{
22
//Sleep 5 Seconds
23
System.Threading.Thread.Sleep(TimeSpan.FromSeconds(5));
24data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
25 //show time
26
this.Label1.Text = DateTime.Now.ToLongTimeString();
27
}
28
}
data:image/s3,"s3://crabby-images/951a9/951a9c99c3e9d473288a3a429857325952eefdb7" alt=""
02
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
03
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
04
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
05
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
06
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
07
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
08
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
09
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
10
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
11
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
12
data:image/s3,"s3://crabby-images/4e083/4e083420da3c654ef1864b54dc34c6ff578f43e9" alt=""
13
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
14
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
15
data:image/s3,"s3://crabby-images/951a9/951a9c99c3e9d473288a3a429857325952eefdb7" alt=""
16
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
17
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
18
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
19
data:image/s3,"s3://crabby-images/8205b/8205b2681b4eac0eb471ffe53696eecf47638e0c" alt=""
20
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
21
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
22
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
23
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
24
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
25 //show time
26
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
27
data:image/s3,"s3://crabby-images/8205b/8205b2681b4eac0eb471ffe53696eecf47638e0c" alt=""
28
data:image/s3,"s3://crabby-images/4e083/4e083420da3c654ef1864b54dc34c6ff578f43e9" alt=""
執行結果: