0

在網絡表單中,我有一個複選框和3個文本框。我將所需的字段驗證器添加到所有3個文本框。我希望textbox1只有在複選框被選中時纔是必需的。我想用javascript來做。我正在使用customvalidator,我不知道我在哪裏做錯了。以下是我的代碼。使用javascript禁用asp驗證器

<form id="form1" runat="server"> 
<div> 
    <asp:CheckBox Checked="false" ID="chkBox" runat="server"/> 
    <asp:TextBox ID="txtBox1" Enabled="true" runat="server" /> 
    <asp:CustomValidator id="newcstvalid" runat="server" ClientValidationFunction="CheckBoxValidation"></asp:CustomValidator> 
    <asp:RequiredFieldValidator runat="server" ID="rfvchkbox" ControlToValidate="txtBox1" ErrorMessage="error" ValidationGroup="abc"></asp:RequiredFieldValidator> 
    <br /> 

    <asp:TextBox ID="txtBox2" runat="server"></asp:TextBox> 
    <asp:RequiredFieldValidator runat="server" ID="rfvtxt1" ControlToValidate="txtBox2" ErrorMessage="error" ValidationGroup="abc"></asp:RequiredFieldValidator> 
    <br /> 

    <asp:TextBox ID="txtBox3" runat="server"></asp:TextBox> 
    <asp:RequiredFieldValidator runat="server" ID="RequiredFieldValidator1" ControlToValidate="txtBox3" ErrorMessage="error" ValidationGroup="abc"></asp:RequiredFieldValidator> 
    <br /> 

    <asp:Button ID="btnSubmit" runat="server" Text="Button" CausesValidation="true" ValidationGroup="abc"/> 
    <asp:ValidationSummary runat="server" ID="valsumm" ValidationGroup="abc" ShowValidationErrors="true" /> 
</div> 
</form> 

我的javascript功能

<script type="text/javascript"> 
    function CheckBoxValidation() { 
     var myCheckBox = document.getElementById("<%= chkBox.ClientID %>");    
     var validator = document.getElementById("<%= rfvchkbox.ClientID %>"); 
     if (myCheckBox.checked) 
     { ValidatorEnable(validator, true); } 
     else { ValidatorEnable(validator, false); }     
     }   
</script> 

感謝所有

回答

0

你不需要多重校驗來完成你嘗試一下,在這裏。首先,擺脫requiredfieldvalidator「rfvchkbox」 - 你不需要它。

其次,您的CustomValidator缺少一些東西,特別是ControlToValidate。

<asp:CustomValidator id="newcstvalid" runat="server" ClientValidationFunction="CheckBoxValidation" ControlToValidate="txtBox1" ErrorMessage="* Required" ForeColor="Red"></asp:CustomValidator> 

接下來,不是啓用/禁用單獨的控件,您的函數應該將args.isValid屬性設置爲true或false。

function CheckBoxValidation(source, args) { 
     if ($("<%=chkBox.ClientID%>").checked && args.toString().length == 0) 
      args.IsValid = false; 
     else 
      args.IsValid = true; 
     } 

退房MSDN文檔:http://msdn.microsoft.com/en-us/library/aa479045.aspx

我也建議一個更具描述性錯誤消息,爲你的校驗不是「錯誤」