JQuery валидизировать зависимое поле
Привет, ребята,
Я пытаюсь использовать плагин проверки jQuery и указать, что одно поле является обязательным только тогда, когда 3 других поля не заполнены (не заполнены).
Дело в том, что правило работает, но оно по-прежнему требует поля, даже когда я набираю на нем значение.
Благодарю.
Это мой код:
$("#ProspectDtlFrm").validate({
rules: {
prsptEmail: {
required: function(element) { return ( $("#prsptHomePhone").val() == '' && $("#prsptBusinessPhone").val() == '' && $("#prsptMobilePhone").val() =='') }
}
},
messages: {
prsptEmail: "Please enter your first name"
}
});
4 ответа
Вы могли бы использовать depends
:
$('#ProspectDtlFrm').validate({
rules: {
prsptEmail: {
required: {
depends: function(element) {
return ($('#prsptHomePhone').val() == '' &&
$('#prsptBusinessPhone').val() == '' &&
$('#prsptMobilePhone').val() == '');
}
}
}
},
messages: {
prsptEmail: 'Please enter your first name'
}
});
depends
предложение все еще поддерживается. Это версия 1.11.0pre:
normalizeRules: function(rules, element) {
// handle dependency check
$.each(rules, function(prop, val) {
// ignore rule when param is explicitly false, eg. required:false
if (val === false) {
delete rules[prop];
return;
}
if (val.param || val.depends) {
var keepRule = true;
switch (typeof val.depends) {
case "string":
keepRule = !!$(val.depends, element.form).length;
break;
case "function":
keepRule = val.depends.call(element, element);
break;
}
if (keepRule) {
rules[prop] = val.param !== undefined ? val.param : true;
} else {
delete rules[prop];
}
}
});
Как видите, вы можете выбирать между "строкой" и "функцией". Таким образом, вы можете использовать:
rules: {
input_name_here: {
required: {
depends: function(element) {
return $("#thickBoxId:checked").length;
//or whatever you need to check
}
}
}
}
Или же
rules:{
input_name_here:{
required: '#tickBoxId:checked'
}
}
Если вам нужно только проверить на наличие чего-то проверенного.
"зависит" кажется, что он больше не поддерживается, и их документы не обновлены.
Таким образом, в сценарии, где, если установлен флажок "да", проверьте другое поле:
rules:{
'name value of area you want to validate':{
required: '#tickBoxId:checked'
}
}
Путь depends
это работает.
rules: {
prsptEmail: {
required: {
depends: function(element){
if ($('#id-user').val() == '') {
return true;
} else {
return false;
}
}
}
},
},
messages: {
prsptEmail : {
required : "please signIn!",
}
},
Только для этого сценария есть функция:
require_from_group
метод.
https://jqueryvalidation.org/require_from_group-method
Описание: Обеспечивает заполнение заданного количества полей в группе.
В параметрах, переданных правилу, укажите минимальное количество полей в группе, которые должны быть заполнены, и селектор для определения группы. Затем примените это правило ко всем полям в группе. В таком случае форму нельзя отправить, пока не будет заполнено хотя бы минимальное количество.
Часть файла additional-methods.js
Я скопировал пример из документации в этот фрагмент:
$("#myform").validate({
rules: {
mobile_phone: {
require_from_group: [1, ".phone-group"]
},
home_phone: {
require_from_group: [1, ".phone-group"]
},
work_phone: {
require_from_group: [1, ".phone-group"]
}
}
});
<script src="https://code.jquery.com/jquery-1.11.1.min.js"></script>
<script src="https://cdn.jsdelivr.net/jquery.validation/1.16.0/jquery.validate.min.js"></script>
<script src="https://cdn.jsdelivr.net/jquery.validation/1.16.0/additional-methods.min.js"></script>
<form id="myform">
<label for="mobile_phone">Mobile phone: </label>
<input class="phone-group" id="mobile_phone" name="mobile_phone">
<br/>
<label for="home_phone">Home phone: </label>
<input class="phone-group" id="home_phone" name="home_phone">
<br/>
<label for="work_phone">Work phone: </label>
<input class="phone-group" id="work_phone" name="work_phone">
</form>