美文网首页前端资源库Web前端之路让前端飞
解决bootstrap下拉菜单点击立即隐藏的bug

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

作者: 多小啦 | 来源:发表于2017-06-12 23:34 被阅读70次

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


    image.png

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

    var banks = $('.all').siblings().children();
    $('.all>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);
    })
    
    
    image.png

    相关文章

      网友评论

      本文标题:解决bootstrap下拉菜单点击立即隐藏的bug

      本文链接:https://www.haomeiwen.com/subject/hvmrqxtx.html