如何在加载和启用期间禁用 asp.button

How to Disable asp.button during loading and enable

我正在寻找一种在调用方法之前禁用按钮并在方法结束时启用按钮的方法。

代码应该是这样的:

Btn.Enabled = false;
MyMethode();
Btn.Enabled = true;

但是按钮仍然可用。

注意:所有控件都在 UpdatePanel 中。

我试过 Js:

ScriptManager.RegisterStartupScript(this, GetType(), "showalert", "document.getElementById('BtnClone').disabled = true; ", true);

ScriptManager.RegisterStartupScript(this, GetType(), "showalert", "document.getElementById('BtnClone').disabled = false; ", true);

按钮保持启用状态。

谢谢

您可以提供的解决方案是,一旦 post 后台启动,您就可以使用加载 gif 图像,将以下代码放在母版页中

  <asp:ScriptManager EnablePartialRendering="true" ID="ScriptManagerMain" runat="server"
    AsyncPostBackTimeout="360000">
</asp:ScriptManager>

母版页Content占位符之前,放上下面的更新进度

<script type="text/javascript" language="javascript">
            var ModalProgress = '<%= ModalProgress.ClientID %>';         
        </script>
        <script type="text/javascript" src="Scripts/js/jsUpdateProgress.js">
</script>
<asp:Panel ID="panelUpdateProgress" runat="server" CssClass="updateProgress">
            <asp:UpdateProgress ID="UpdateProg1" DisplayAfter="0" runat="server">
                <ProgressTemplate>
                    <div class="divWaiting">
                        <img id="progressImg" src="img/App/Rolling.gif" alt="Processing" height="60px" width="60px" />
                    </div>
                </ProgressTemplate>
            </asp:UpdateProgress>
        </asp:Panel>
        <cc1:ModalPopupExtender ID="ModalProgress" runat="server" TargetControlID="panelUpdateProgress"
            BackgroundCssClass="modalBackground" PopupControlID="panelUpdateProgress" />

进度Div中使用的CSS如下

.divWaiting
    {
        position: fixed;
        background-color: #313130;
        z-index: 2147483647 !important;
        opacity: 0.8;
        overflow: hidden;
        text-align: center;
        top: 0;
        left: 0;
        height: 100%;
        width: 100%;
        padding-top: 30%;
    }

jsUpdateProgress.js代码如下,

Sys.WebForms.PageRequestManager.getInstance().add_beginRequest(beginReq);
Sys.WebForms.PageRequestManager.getInstance().add_endRequest(endReq);

function beginReq(sender, args) {
    // shows the Popup 
    $find(ModalProgress).show();
}

function endReq(sender, args) {
    //  hides the Popup 
    $find(ModalProgress).hide();
}

试试这个,它会在 post 后台开始时打开加载 GIF,并在 post 后台结束时结束。这将防止双击

我已经在 aspx 中用这段代码解决了问题。

<ProgressTemplate>
            <div style="position: fixed; text-align: center; height: 100%; width: 100%; top: 0; right: 0; left: 0; z-index: 9999999; background-color: #000000; opacity: 0.7;">
                <span style="border-width: 0px; position: fixed; padding: 50px; background-color: #FFFFFF; font-size: 36px; left: 40%; top: 40%;">Loading ...</span>
            </div>
        </ProgressTemplate>

它正在创建一条加载消息,直到更新面板准备就绪。