gpt4 book ai didi

javascript - CustomValidator 客户端验证功能未触发

转载 作者:数据小太阳 更新时间:2023-10-29 04:55:58 24 4
gpt4 key购买 nike

我认为我试图做的事情是微不足道的,但结果却给我带来了很大的麻烦。这是情况。

我有两个单选按钮(使用 RadButton 实现)和一个 RadTextBox。我想检查客户端,然后在选择两个 radio 按钮之一时提交表单,即RadTextbox并非空(例如,第一个)。我使用了 CustomValidator 并且将 ValidateEmptyText="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 的新的非侵入式验证模式有关。要使其正常工作,需要 jQuery 2.0。这是 .NET 4.5 中的标准。然而,RadControls 中的嵌入式 jQuery 版本(至少版本 2013Q3)是 v1.9.1(参见 here)。结果 CustomValidator不再正常工作。

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

  1. 禁用不显眼的验证模式。为此,您需要在 <appSettings> 中包含以下行节web.config文件:

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

    缺点:不显眼的验证模式旨在利用新的 HTML5 功能,以消除为执行验证而生成的 javascript 代码,从而使页面更轻(请参阅 here)。通过禁用它,您没有使用此功能。

  2. 选择不为 RadControls 使用嵌入式版本的 jQuery(即 v1.9.1),而是使用 .NET 4.5 提供的版本(即 v2.0)。

    缺点:这里的问题是 RadControls 已经使用 jQuery 的嵌入式版本进行了测试,您可能会遇到问题。要禁用 jQuery 的嵌入式版本,请参阅 this link

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

关于javascript - CustomValidator 客户端验证功能未触发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19847874/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com