default.aspx 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. <%@ Page Language="C#" %>
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  3. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  4. <script runat="server">
  5. protected void ButtonClick_Handler(object sender, EventArgs e)
  6. {
  7. System.Threading.Thread.Sleep(3000);
  8. }
  9. </script>
  10. <html xmlns="http://www.w3.org/1999/xhtml">
  11. <head id="Head1" runat="server">
  12. <title>PageRequestManager initializeRequest Example</title>
  13. <style type="text/css">
  14. body {
  15. font-family: Tahoma;
  16. }
  17. a {
  18. text-decoration: none;
  19. }
  20. a:hover {
  21. text-decoration: underline;
  22. }
  23. div.UpdatePanelStyle{
  24. width: 300px;
  25. height: 300px;
  26. }
  27. div.AlertStyle {
  28. font-size: smaller;
  29. background-color: #FFC080;
  30. height: 20px;
  31. visibility: hidden;
  32. }
  33. div.Container {
  34. display: inline;
  35. float: left;
  36. width: 330px;
  37. height: 300px;
  38. }
  39. </style>
  40. </head>
  41. <body>
  42. <form id="form1" runat="server">
  43. <div>
  44. <asp:ScriptManager ID="ScriptManager1" runat="server" />
  45. <script type="text/javascript" language="javascript">
  46. var divElem = 'AlertDiv';
  47. var messageElem = 'AlertMessage';
  48. Sys.WebForms.PageRequestManager.getInstance().add_initializeRequest(CheckStatus);
  49. function CheckStatus(sender, args)
  50. {
  51. var prm = Sys.WebForms.PageRequestManager.getInstance();
  52. if (prm.get_isInAsyncPostBack() & args.get_postBackElement().id == 'CancelRefresh') {
  53. prm.abortPostBack();
  54. }
  55. else if (prm.get_isInAsyncPostBack() & args.get_postBackElement().id == 'RefreshButton') {
  56. args.set_cancel(true);
  57. ActivateAlertDiv('visible', 'Still working on previous request.');
  58. }
  59. else if (!prm.get_isInAsyncPostBack() & args.get_postBackElement().id == 'RefreshButton') {
  60. ActivateAlertDiv('visible', 'Processing....');
  61. }
  62. }
  63. function ActivateAlertDiv(visString, msg)
  64. {
  65. var adiv = $get(divElem);
  66. var aspan = $get(messageElem);
  67. adiv.style.visibility = visString;
  68. aspan.innerHTML = msg;
  69. }
  70. </script>
  71. <div class="Container" >
  72. <asp:UpdatePanel ID="UpdatePanel1" UpdateMode="Conditional" runat="Server" >
  73. <ContentTemplate>
  74. <asp:Panel ID="Panel1" runat="server" GroupingText="UpdatePanel"
  75. CssClass="UpdatePanelStyle">
  76. Last update:
  77. <%=DateTime.Now.ToString() %>.
  78. <asp:Button runat="server" ID="RefreshButton" Text="Refresh"
  79. OnClick="ButtonClick_Handler" />
  80. <div id="AlertDiv" class="AlertStyle">
  81. <span id="AlertMessage"></span> &nbsp;&nbsp;&nbsp;&nbsp;
  82. <asp:LinkButton ID="CancelRefresh" runat="server">cancel</asp:LinkButton>
  83. </div>
  84. </asp:Panel>
  85. </ContentTemplate>
  86. </asp:UpdatePanel>
  87. </div>
  88. </div>
  89. </form>
  90. </body>
  91. </html>