gpt4 book ai didi

jQuery 验证 – 选中复选框时检查输入值

转载 作者:行者123 更新时间:2023-12-01 04:23:29 25 4
gpt4 key购买 nike

我有一个电话号码输入字段,其中包含短信更新选项。我想检查当选中短信复选框时该号码是否是手机号码。我已经使正则表达式正常工作,并且正在验证,但即使未选中复选框,也会显示“移动要求”错误。

$.validator.addMethod(
"regex",
function(value, element, regexp) {
if($('#receive_sms_updates').is(':checked')) {
var check = false;
var re = new RegExp(regexp);
return this.optional(element) || re.test(value);
}
}, "Mobile Required"
);


$("form#patient-detials").validate({
rules: {
'patient[person_attributes][phone_mobile]': {
maxlength: 10,
minlength: 10,
digits: true,
regex: "^04[0-9]{8}"
}
}
});

最佳答案

更新(来自您下面的评论)。

如果未输入 if,您的自定义规则就不会返回 true,从技术上讲,这会导致 undefined 返回给调用者(这是一个 < em>错误的值)。按如下方式更新您的规则:

$.validator.addMethod("regex", function(value, element, regexp) {
if ($('#receive_sms_updates').is(':checked')) {
var check = false;
var re = new RegExp(regexp);
return this.optional(element) || re.test(value);
}
return true;
}, "Mobile Required");

保留这部分,因为它可能对其他人有用:

我将更新您的验证调用和规则,如下所示:

$.validator.addMethod("regex", function(value, element, regexp) {
var re = new RegExp(regexp);
return this.optional(element) || re.test(value);
}, "Mobile Required");

$("form#patient-detials").validate({
rules: {
'patient[person_attributes][phone_mobile]': {
maxlength: 10,
minlength: 10,
digits: true,
regex: "^04[0-9]{8}",
required: "#receive_sms_updates:checked"
}
}
});

如您所见,required 属性采用“依赖表达式”,用于确定移动字段是否为必填(基于是否#receive_sms_updates 已选中)。

这是一个示例: http://jsfiddle.net/andrewwhitaker/ED6cX/

<小时/>

为了更进一步,我建议从规则本身中删除“Mobile required”方法(毕竟您需要一个可重复使用的正则表达式规则),并将其放在消息 验证调用中的属性。像这样的东西:

$.validator.addMethod("regex", function(value, element, regexp) {
var re = new RegExp(regexp);
return this.optional(element) || re.test(value);
});

$("form#patient-detials").validate({
rules: {
'patient[person_attributes][phone_mobile]': {
maxlength: 10,
minlength: 10,
digits: true,
regex: "^04[0-9]{8}",
required: "#receive_sms_updates:checked"
}
},
messages: {
'patient[person_attributes][phone_mobile]': {
required: "Mobile Required",
regex: "Please enter a valid mobile number"
}
}
});

示例: http://jsfiddle.net/andrewwhitaker/5BVCK/

这样,您就不会使用特定的表单来限制您的验证规则(该规则足够通用,可以应用于其他字段)。

关于jQuery 验证 – 选中复选框时检查输入值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8483761/

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