3

这是标记:

<asp:UpdatePanel ID="UpdatePanel1" runat="server">
    <ContentTemplate>
        <div class="well well-large">
            <form class="navbar-form pull-left">
                <asp:FileUpload ID="test" runat="server" CssClass="input-small" />
                <br />
                <asp:Button ID="btnUpload" runat="server" Text="Upload" CssClass="btn" OnClick="btnUpload_Click" />
            </form>
        </div>
    </ContentTemplate>
    <Triggers>
        <asp:AsyncPostBackTrigger ControlID="btnUpload" EventName="Click" />
    </Triggers>
</asp:UpdatePanel>

<asp:Panel runat="server" ID="panAlert" Visible="false">
    <div class="alert alert-success" id="divAlert" runat="server">
        <button id="Button1" runat="server" type="button" class="close" data-dismiss="alert">&times;</button>
        You shouldn't see this message!
    </div>
    <asp:Panel runat="server" ID="panMarquee" Visible="true">
        <div id="Div1" runat="server" class="progress progress-success progress-striped">
            <div id="ProgressBar" runat="server" class="bar" style="width: 100%"></div>
        </div>
    </asp:Panel>
</asp:Panel>

单击 btnUpload 按钮时,服务器代码应该确定 FileUpload 控件是否有文件。如果是这样,它会将 Panel 控件的可见性更改为 true。它在 UpdatePanel 之外工作正常。

这是服务器代码:

protected void btnUpload_Click(object sender, EventArgs e)
    {
        this.SetMessage(Message.Success);
        try
        {
            if (this.test.HasFile)
            {
                string filename = Path.GetFileName(GetUB04Doc.FileName);
                //test.SaveAs(Server.MapPath("~/") + filename);
                this.SetMessage(Message.Success);
            }
        }
        catch (Exception ex)
        {
            //TODO: Do something with th exception
            this.SetMessage(Message.Fail);
        }
        finally
        {
            //this.GetUB04Doc.Dispose();
        }
    }
private enum Message { Success, Fail }
    private void SetMessage(Message msg)
    {
        if (msg == Message.Success)
        {
            this.divAlert.InnerText = "Well done! The document appears to have uploaded successfully. Please wait...";
            this.divAlert.Attributes.Add("class", "alert alert-success");
        }
        else
        {
            this.divAlert.InnerText = "Oh snap! Something broke. Please contact IT right away.";
            this.divAlert.Attributes.Add("class", "alert alert-error");
        }

        this.panAlert.Visible = true;
    }

我也尝试将 Panel 放入 ContentTemplate 部分,但结果相同。

关于我在这里做错了什么的任何想法?

4

2 回答 2

3

您应该将要从另一个异步回发中修改的区域包围起来,并将UpdatePanelUpdateMode设置为Conditional. 然后从代码隐藏中手动更新另一个:

<asp:UpdatePanel ID="panAlertUpdatePanel" UpdateMode="Conditional" runat="server">
    <ContentTemplate>
    <asp:Panel runat="server" ID="panAlert" Visible="false">
        <!-- ....

代码隐藏:

// ...
this.panAlert.Visible = true;
panAlertUpdatePanel.Update()

旁注:正如@Belogix 已经评论的那样,您应该在一个常规控件中使用一个AsyncFileUpload控件,因为异步回发不支持它。UpdatePanelFileUpload

MSDN

与 UpdatePanel 控件不兼容的控件:

  • ...
  • FileUploadHtmlInputFile控制它们何时用于作为异步回发的一部分上传文件。
  • ...

要在 UpdatePanel 控件中使用 FileUpload 或 HtmlInputFile 控件,请将提交文件的回发控件设置为面板的 PostBackTrigger 控件。FileUpload 和 HtmlInputFile 控件只能在回发方案中使用。

于 2013-05-22T14:57:37.713 回答
0

你需要把PostBackTrigger而不是AsyncPostBackTrigger这样。<asp:PostBackTrigger ControlID="btnUpload" />

于 2013-05-22T14:56:22.773 回答