-1

我正在使用进度条和必填字段验证器。但是当我点击提交按钮时。进度条和验证器消息都显示了。我的代码是

<script type="text/javascript">

    function ShowDiv() {
        setTimeout('document.getElementById("PB").style.display = "inline";', 500); 
    }

</script>
...
<asp:Button ID="btnSubmit" runat="server" Text="Submit" ValidationGroup="ValGrpSave" onclick="btnSubmit_Click" OnClientClick="ShowDiv()" />
...
<asp:TextBox ID="txtEmail1" Width="350px" runat="server" />
<asp:RequiredFieldValidator ID="RequiredFieldValidator2" runat="server" ValidationGroup="ValGrpSave" ErrorMessage="<b>Field Missing</b><br/>Issue no is Required" Display="None" ControlToValidate="txtEmail1" />
<cc1:ValidatorCalloutExtender ID="ValidatorCalloutExtender2" runat="server" TargetControlID="RequiredFieldValidator2" />
4

1 回答 1

0

问题是您没有阻止您的按钮开始提交表单,并且由于您的表单无效,您的验证器会显示消息。

如果您的按钮只应该显示进度条,请尝试将您的脚本功能更改为此(将其更改为非服务器按钮是一个不同的争论,因为它没有任何服务器端功能,但让我们把它留给您):

function ShowDiv(evt) {

    // display progress bar after half a second
    setTimeout(function() {
         document.getElementById("PB").style.display = "inline";
    }, 500);

    // prevent button click event propagation thus prevent form submission
    evt.preventDefault();
    return false;
}

我也更改setTimeout为提供一个函数而不是不推荐使用的字符串语句。

并更改您的按钮

<asp:Button ID="btnSubmit" runat="server" Text="Submit" ValidationGroup="ValGrpSave" onclick="btnSubmit_Click" OnClientClick="return ShowDiv();" />
于 2012-07-10T12:56:41.297 回答