更新(来自您下面的评论)。
如果未输入 if,您不会从自定义规则返回 true,这在技术上会导致 undefined 被返回给调用者(这是一个 falsey 值)。更新您的规则如下:
$.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/
为了更进一步,我建议从规则本身中删除“需要移动设备”方法(毕竟您想要一个可重复使用的正则表达式规则),并将其放在您的 messages 属性上验证通话。比如:
$.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/
这样您就不会使用特定的表单来限制您的验证规则(它足够通用,可以应用于其他字段)。