我有一个订单输入页面,可能需要一段时间来处理,用户认为浏览器已经冻结并关闭它。这是一个弹出式浏览器,单击cmdAdd按钮时,文本框中的项目将写入数据库,子窗口将关闭,父窗口将刷新以查看更改。目前运行良好。
我添加了一个AJAX UpdateProgress来给用户一些反馈,但是现在cmdAdd浏览器不会关闭,父浏览器也不会更新。进度指示器会显示,数据库也会更新,但就是这样。有什么想法吗?
注意:UpdateProgress指示器在站点的其他地方使用,没有问题,只是我在弹出的子窗口中使用它。cmdAdd_click在没有updateProgress控件的情况下正常工作(子控件关闭,父控件刷新)
ASPX公司:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="orderHistory.aspx.cs" Inherits="JWeb.orderHistory" %>
<%@ Register assembly="AjaxControlToolkit" namespace="AjaxControlToolkit" tagprefix="asp" %>
<!DOCTYPE html>
<html>
<head id="Head1" runat="server">
<title>JWebUtils - Order History Sheet</title>
<link href="App_Themes/Theme/Styles.css" rel="stylesheet" type="text/css" />
<link href="cssUpdateProgress.css" rel="stylesheet" type="text/css" />
</head>
<body>
<script type="text/javascript">
var ModalProgress = '<%= ModalProgress.ClientID %>';
</script>
<DIV style="width: 700px; vertical-align: top; border-collapse: collapse;" class="pageBody">
<form id="Form1" method="post" runat="server">
<asp:ToolkitScriptManager ID="ToolkitScriptManager1" runat="server">
</asp:ToolkitScriptManager>
<script type="text/javascript" src="jsUpdateProgress.js"></script>
<asp:Panel ID="panelUpdateProgress" runat="server" CssClass="updateProgress">
<asp:UpdateProgress ID="UpdateProg1" DisplayAfter="0" runat="server">
<ProgressTemplate>
<div style="position: relative; top: 30%; text-align: center; vertical-align: middle;">
<img src="images/loading.gif" style="vertical-align: middle" alt="Processing" />
Processing ...
</div>
</ProgressTemplate>
</asp:UpdateProgress>
</asp:Panel>
<asp:ModalPopupExtender ID="ModalProgress" runat="server" TargetControlID="panelUpdateProgress" BackgroundCssClass="modalBackground" PopupControlID="panelUpdateProgress" />
<%-- <asp:button id="cmdAdd" tabIndex="5" runat="server" Width="95px" cssClass="dg_buttons" Text="Add to Order" onclick="cmdAdd_Click"></asp:button>
--%> <asp:UpdatePanel ID="pnlUpdate" runat="server">
<ContentTemplate>
<TABLE id="Table1" style="WIDTH: 100%;">
<TR>
<TD class="pageHeader" colspan="2">
<asp:label id="lblTitle" runat="server" Font-Names="Arial" Font-Bold="True">Order History Sheet</asp:label>
</TD>
</TR>
<TR>
<TD vertical-align: top;" style="width: 220px;">
<asp:button id="cmdAdd" tabIndex="5" runat="server" Width="95px"
cssClass="dg_buttons" Text="Add to Order" onclick="cmdAdd_Click"></asp:button>
<asp:button id="cmdClose" tabIndex="5" runat="server" Width="50px" Text="Close"
CssClass="dg_buttons" onclientclick="window.close(); return false;"></asp:button>
<asp:button id="cmdPrint" tabIndex="5" runat="server" Width="50px" Text="Print"
CssClass="dg_buttons" CausesValidation="False" UseSubmitBehavior="False"></asp:button>
</TD>
<TD vertical-align: top;" style="text-align: right; width: 480px;">
<asp:Label ID="lblCustomerName" runat="server"></asp:Label>
</TD>
</TR>
<TR>
<TD vertical-align: top;" style="vertical-align: top" colspan="2">
<span class="style1">* Qty Bought is total items purchased in the last 12
months from the current date </span>
<table style="WIDTH: 100%; vertical-align: top;">
<TR>
<TD colspan="2">
<asp:label id="lblMessage" runat="server" Font-Names="Arial" Font-Size="Small" Width="525px" ForeColor="Red"></asp:label>
</TD>
</TR>
<TR>
<TD colspan="2">
<div class="mGrid">
<< GRIDVIEW OMITTED FOR BEREVITY >>
</div>
</TD>
</TR>
</table>
</TD>
</TR>
</TABLE>
</ContentTemplate>
</asp:UpdatePanel>
</form>
</DIV>
<script type="text/javascript" src="jsUpdateProgress.js"></script>
</body>
</html>
命令添加单击:
protected void cmdAdd_Click(object sender, EventArgs e)
{
string qty = null;
string itemCode = null;
int orderID = Convert.ToInt32((Session["OrderID"]));
int seqNum = 0;
int orderSeqNum = 0;
string description = null;
JWebUtils.priceType pricing = default(JWebUtils.priceType);
double price = 0;
string type = null;
ArrayList sqlParams = new ArrayList();
JWebDB db = new JWebDB();
System.Text.StringBuilder script = new System.Text.StringBuilder();
int discount = 0;
string strDisc = null;
JWebUtils jweb = new JWebUtils();
<< CODE TO UPDATE DB OMITTED FOR BEREVITY >>
script.Append("<script language=\"javascript\">");
script.Append("window.opener.document.forms[0].submit();self.close();");
script.Append("</script>");
Session["IsPopup"] = true;
ClientScript.RegisterStartupScript(this.GetType(), "XYZ", script.ToString());
}
最佳答案
首先,您应该在页面中添加一个ScriptManager
,然后应该使用:
ScriptManager.RegisterStartupScript(...