BsMultiSelect 和 jQuery 验证兼容性
BsMultiSelect and jQuery Validation compatibility
我有一个网站使用 jQuery Validation for form validation and BsMultiSelect 作为更好的多选字段。问题是 BsMultiSelect 用它自己的 div
替换了 select
元素,我不知道如何验证它。
我有这个 HTML 代码:
<form method="post" id="server-form" class="form-responsive m-auto">
<div class="form-group">
<label for="categories">
Categories
<span class="text-danger">*</span>
</label>
<select name="categories[]" id="categories" class="form-control" multiple="multiple">
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
</div>
<input type="submit" value="Submit" id="submit" class="btn btn-primary">
</form>
还有这个Javascript:
$(function(){
$('#categories').bsMultiSelect();
$('#server-form').validate({
rules:{
'categories[]':{
required: true,
maxlength: 3
}
}
});
});
在没有 BsMultiSelect 的情况下可以工作,但不能与 BsMultiSelect 一起工作。有没有办法让这些插件相互兼容?
1) BsMultiSelect 有自己的 github 项目:https://github.com/DashboardCode/BsMultiSelect .
2) 向其添加自定义验证的选项之一是获取 BsMultiSelect validationApi - 它模拟 HTMLEntity validationApi。
var bsMultiSelect = $('#myselect').BsMultiSelect();
bsMultiSelect.validationApi.setCustomValidity("error message") // or set to "" to remove the message
然后您需要将其与 jquery 验证集成:侦听其事件并添加或删除消息。
我有一个网站使用 jQuery Validation for form validation and BsMultiSelect 作为更好的多选字段。问题是 BsMultiSelect 用它自己的 div
替换了 select
元素,我不知道如何验证它。
我有这个 HTML 代码:
<form method="post" id="server-form" class="form-responsive m-auto">
<div class="form-group">
<label for="categories">
Categories
<span class="text-danger">*</span>
</label>
<select name="categories[]" id="categories" class="form-control" multiple="multiple">
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
</div>
<input type="submit" value="Submit" id="submit" class="btn btn-primary">
</form>
还有这个Javascript:
$(function(){
$('#categories').bsMultiSelect();
$('#server-form').validate({
rules:{
'categories[]':{
required: true,
maxlength: 3
}
}
});
});
在没有 BsMultiSelect 的情况下可以工作,但不能与 BsMultiSelect 一起工作。有没有办法让这些插件相互兼容?
1) BsMultiSelect 有自己的 github 项目:https://github.com/DashboardCode/BsMultiSelect .
2) 向其添加自定义验证的选项之一是获取 BsMultiSelect validationApi - 它模拟 HTMLEntity validationApi。
var bsMultiSelect = $('#myselect').BsMultiSelect();
bsMultiSelect.validationApi.setCustomValidity("error message") // or set to "" to remove the message
然后您需要将其与 jquery 验证集成:侦听其事件并添加或删除消息。