One of the problems with Ajax, is the fact that since it's asynchronus and in the background, the browser will not show you any status. With fast servers and fast methods, this is not a big problem, but whenever you have a method which takes up a bit of time, the user is very likely to get impatient. Fortunately, ASP.NET AJAX solves this problem for us as well, with a nice control called UpdateProgress. It will use your own template to show that an asynchronus method is working. Have a look at the following example, which will show the control in action. It will be explained afterwards.
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>.
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
-
- <head runat="server">
- <title>UpdateProgress control</title>
- </head>
-
- <body>
- <form id="form1" runat="server">
- <asp:ScriptManager ID="ScriptManager1" runat="server" />
- <asp:UpdateProgress runat="server" id="PageUpdateProgress">
- <ProgressTemplate>
- Loading...
- </ProgressTemplate>
- </asp:UpdateProgress>
- <asp:UpdatePanel runat="server" id="Panel">
- <ContentTemplate>
- <asp:Button runat="server" id="UpdateButton" onclick="UpdateButton_Click" text="Update" />
- </ContentTemplate>
- </asp:UpdatePanel>
- </form>
- </body>
-
- </html>
The following method should be added to your CodeBehind file:
- protected void UpdateButton_Click(object sender, EventArgs e)
-
- {
- System.Threading.Thread.Sleep(5000);
- }