0

我遇到了一个与 AsyncFileUpload 控件相关的奇怪问题。上传后,我通过从 ClientUploadComplete 事件处理程序调用 __doPostBack 函数来更新页面。它第一次工作正常,但下次我尝试上传文件时,它会在上传之前先刷新页面,然后上传并再次刷新页面。不知道为什么在上传之前和上传之后调用了两次刷新页面。我有这个代码的简化版本,它有这个错误。请提供任何线索为什么会这样?

标记:

    <form id="form1" runat="server">
<asp:ToolkitScriptManager ID="ToolkitScriptManager1" runat="server">
</asp:ToolkitScriptManager>
<div>
    <asp:UpdatePanel ID="UpdatePanel2" runat="server" UpdateMode="Conditional">
        <ContentTemplate>
            <asp:AsyncFileUpload ID="AsyncFileUpload1" runat="server" OnClientUploadComplete="AsyncFileUpload1_ClientUploadComplete"
                OnUploadedComplete="AsyncFileUpload1_UploadedComplete" />                
        </ContentTemplate>
    </asp:UpdatePanel>
</div>
<asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Conditional">
    <ContentTemplate>
        <asp:Button ID="Button1" runat="server" Text="Refresh Data" OnClick="Button1_Click" />
        <asp:Label ID="Label1" runat="server" EnableViewState="false"></asp:Label>
    </ContentTemplate>
</asp:UpdatePanel>
</form>

Javascript:

    <script type="text/javascript">
    function AsyncFileUpload1_ClientUploadComplete() {
        var btnRefreshData = $get("<%=Button1.ClientID%>").name;
        __doPostBack(btnRefreshData, "");
    }

</script>

代码隐藏:

        protected void Button1_Click(object sender, EventArgs e)
    {
        Label1.Text = "Upload complete";
    }

    protected void AsyncFileUpload1_UploadedComplete(object sender, AjaxControlToolkit.AsyncFileUploadEventArgs e)
    {
        System.Threading.Thread.Sleep(3000);
    }
4

1 回答 1

0

好像没有人能回答这个问题。我还没有弄清楚为什么会发生这种情况,但是我通过在上传完成时在会话中添加一个标志并在刷新页面上的数据之前检查该标志来解决此问题。这样数据刷新不会在上传之前发生。谢谢。

于 2011-01-28T16:21:17.970 回答