I want to show a custom message for one rule and default message for all other rules. For example:
$("#form").validate({
rules: {
"ref": {
required: true,
minlength: 5,
maxlength: 5,
number: true
}
},
messages: {
"ref": {
required: "Please, enter a reference",
default: 'Please enter exact 5 numbers only'
}
}
});
But, it's not working. It works if I repeat the message for all other rules such as:
messages: {
"ref": {
required: "Please, enter a reference",
minlength: 'Please enter exact 5 numbers only',
maxlength: 'Please enter exact 5 numbers only',
number: 'Please enter exact 5 numbers only'
}
}
Repeating the message for all other rules is only way to achieve this or there is a better way?
$("#form").validate({
rules: {
"ref": {
required: true,
minlength: 5,
maxlength: 5,
number: true
}
},
messages: {
"ref": {
required: "Please, enter a reference",
default: 'Please enter exact 5 numbers only'
}
},
submitHandler: function (form) { // for demo
console.log('valid form submitted'); // for demo
return false; // for demo
}
});
body {
padding: 20px;
}
label {
display: block;
}
input.error {
border: 1px solid red;
}
label.error {
font-weight: normal;
color: red;
}
button {
display: block;
margin-top: 20px;
}
<link rel="stylesheet" href="http://netdna.bootstrapcdn.com/bootstrap/3.0.3/css/bootstrap.min.css">
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="http://ajax.aspnetcdn.com/ajax/jquery.validate/1.11.0/jquery.validate.min.js"></script>
<script src="http://ajax.aspnetcdn.com/ajax/jquery.validate/1.11.0/additional-methods.js"></script>
<form id="form" method="post" action="#">
<label for="name">Reference</label>
<input type="text" name="ref" id="ref" />
<button type="submit">Submit</button>
</form>