更新(从下面的评论)。
如果没有输入if
,这在技术上导致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");
左右离开这个部分,因为它可能对别人有用:
我会作如下更新您调用validate和规则:
$.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/
这样,你是不是限制你的验证规则(这是通用的,它可以应用到其他领域)与特定形式。
谢谢安德鲁。前三条规则现在仅在勾选复选框时应用,并且可以将表单提交为空。我仍然希望默认情况下需要一个10位数的数字,并且只需要一个以04开头的数字,如果#receive_sms_updates被选中。 –
@AaronMoodie:啊,我明白了。在这种情况下,我认为你只是缺少自定义规则中的一行。请看我更新的答案。 –
啊,简单。万分感谢。 –