解决bootstrap下拉菜单点击立即隐藏bug的方法

前端之家收集整理的这篇文章主要介绍了解决bootstrap下拉菜单点击立即隐藏bug的方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

昨天用jQuery和bootstrap实现下拉菜单复选框,今天把做好的demo组合进项目里,发现有点bug,就是点击银行复选框的时候,每点一次dropdown-menu这个div会立即隐藏,这就导致每次只能选一个。

这应该是事件传播的原因,代码修改如下:

input').click(function() { var flag = $(this).prop('checked'); banks.prop('checked',flag); })

// 阻止事件传播,否则在点击复选框的时候,dropdown-menu这个div会立即隐藏
$('.dropdown-menu label').click(function(e) {
e.stopPropagation();
});
banks.click(function() {
// 如果有一个没选中,全选按钮不选中
// 如果全部选中,全选按钮被选中
var num = 0;
banks.each(function() {
if ($(this).prop("checked")) {
num++;
}
})
if (num == banks.length) {
$('.all>input').prop('checked',true);
} else {
$('.all>input').prop('checked',false);
}
})

另外,需要新增加功能是,点击“保存”按钮的时候,需要把选中的银行名称以逗号拼接成字符串传递给后台。这部分比较简单,代码如下:

获取选中的所有值,并把这些值拼接成字符串 $('.submit').click(function() { var bankArr = []; banks.each(function() { if ($(this).prop("checked")) { bankArr.push($(this).val()); } }); var bankStr = bankArr.join(','); console.log(bankStr); })

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

原文链接:https://www.f2er.com/bootstrap/38659.html

猜你在找的Bootstrap相关文章