我以为我试图做的事情是微不足道的,但事实证明这给我带来了重大困扰。这是情况。

我有两个无线电按钮(使用Radbutton实施)和一个RadTextbox。我想检查客户端,然后在选择两个无线电按钮之一时提交表单,即RadTextbox并非空(例如,第一个)。我已经使用了CustomValidator,并且已经设置了vasileSectyText =“ true”至无运气。代码的摘录如下:

<asp:Panel runat="server" ID="Panel1">
<table>
    <tr>
        <td class="auto-style5">
            <telerik:RadButton ID="rdBtnIndividual" runat="server" AutoPostBack="False" GroupName="rdEmplrType" 
                Text="Individual" ToggleType="Radio" OnClientCheckedChanged="rdBtnPhysical_CheckedChanged" 
                UseSubmitBehavior="False">
                <ToggleStates>
                    <telerik:RadButtonToggleState PrimaryIconCssClass="rbToggleRadioChecked" />
                    <telerik:RadButtonToggleState PrimaryIconCssClass="rbToggleRadio" />
                </ToggleStates>
            </telerik:RadButton>
        </td>
        <td>
            <telerik:RadButton ID="rdBtnLegal" runat="server" AutoPostBack="False" GroupName="rdEmplrType" Text="Legal Entity" 
                ToggleType="Radio" OnClientCheckedChanged="rdBtnLegal_CheckedChanged" UseSubmitBehavior="False">
                <ToggleStates>
                    <telerik:RadButtonToggleState PrimaryIconCssClass="rbToggleRadioChecked" />
                    <telerik:RadButtonToggleState PrimaryIconCssClass="rbToggleRadio" />
                </ToggleStates>
            </telerik:RadButton>
        </td>
    </tr>
    <tr>
        <td class="auto-style5">
            <label>Name:</label>
        </td>
        <td>
            <telerik:RadTextBox ID="txtName" Runat="server" EmptyMessage="Name" LabelWidth="64px" Resize="None" Width="160px" DisabledStyle-BackColor="Silver">
            </telerik:RadTextBox>
        </td>
        <td><asp:RequiredFieldValidator ID="THIS_IS_WORKING" ControlToValidate="txtName"
                runat="server" ErrorMessage="<img src='images/Exclamation.png' Title='Required Field'/>" >
            </asp:RequiredFieldValidator>
        </td>
    </tr>
    <tr>
        <td class="auto-style5">
            <label>Father's Name</label>
        </td>
        <td style="width:100px">
            <telerik:RadTextBox ID="txtFathersName" Runat="server" EmptyMessage="Father's Name" LabelWidth="64px" Resize="None" Width="160px" DisabledStyle-BackColor="Silver">
            </telerik:RadTextBox>
        </td>
        <td>
            <asp:CustomValidator runat="server" ID="NOT_WORKING_VALIDATOR" ControlToValidate="txtFathersName" ValidateEmptyText="True"
                ClientValidationFunction="RequiredIfIndividual"
                ErrorMessage="<img src='images/Exclamation.png' Title='Required Field'/>" EnableClientScript="True">
            </asp:CustomValidator>

        </td>
    </tr>
</table>
</asp:Panel>

JavaScript如下:

<script type="text/javascript">
    function RequiredIfIndividual(sender, args) {
        var chkBoxIndividual = $find("<%=rdBtnIndividual.ClientID%>");
        chkBoxIndividual = $telerik.toButton(chkBoxIndividual);
        if (chkBoxIndividual.get_checked()) {
            if (args.Value == "") {
                args.IsValid = false;
            }
            else {
                args.IsValid = true;
            }
        } else {
            args.IsValid = true;
        }
    }

</script>
有帮助吗?

解决方案

花了一些时间来解决这个问题,我设法找到了问题的根本原因。

该问题与.NET 4.5的新的不引人注目的验证模式有关。为此,需要正常工作。这是.NET 4.5中的标准配置。但是,radcontrols中的嵌入式jQuery版本(至少为2013Q3版本)为v1.9.1(请参阅 这里)。结果 CustomValidator 无法正常工作。

有两种选择 - 我只尝试了第一个成功:

  1. 禁用不引人注目的验证模式。为此,您需要在 <appSettings> 部分 web.config 文件:

    <add key="ValidationSettings:UnobtrusiveValidationMode" value="None" />

    缺点:不引人注目的验证模式旨在使新的HTML5功能成为SE,以消除生成的JavaScript代码以执行验证,从而产生较轻的页面(请参阅 这里)。通过禁用它,您不会使用此功能。

  2. 选择不使用radcontrols的JQuery的嵌入式版本(即v1.9.1),并使用.NET 4.5(IE v2.0)提供的版本。

    缺点:这里的问题是,RadControl已使用JQuery的嵌入式版本进行了测试,您可能会遇到问题。为了禁用JQuery的嵌入式版本,请参考 这个链接

希望这将帮助下一个偶然发现同样问题的人。

其他提示

您需要手动调用valioratorValidate函数,并从rdbtnphysical_checkedchanged和rdbtnlegal_checkedchedchanged handlers中传递自定义验证器实例。我在下面为您准备了一个简短的例子:

  <script type="text/javascript">
            function RequiredIfIndividual(sender, args) {
                var chkBoxIndividual = $find("<%=rdBtnIndividual.ClientID%>");
                chkBoxIndividual = $telerik.toButton(chkBoxIndividual);
                if (chkBoxIndividual.get_checked()) {
                    if (args.Value == "") {
                        args.IsValid = false;
                    }
                    else {
                        args.IsValid = true;
                    }
                } else {
                    args.IsValid = true;
                }
            }

            function rdBtnPhysical_CheckedChanged(sender, args) {
                ValidatorValidate($get("NOT_WORKING_VALIDATOR"));
            }

            function rdBtnLegal_CheckedChanged(sender, args) {
                ValidatorValidate($get("NOT_WORKING_VALIDATOR"));
            }

        </script>

我刚刚测试了代码,似乎可以正常工作。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top