关于JQuery全选/反选第二次失效的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于JQuery全选/反选第二次失效的问题相关的知识,希望对你有一定的参考价值。

  最近在项目中,遇到一个问题,测试全选/反选功能时,第一次对母框进行选中/非选中时,能同步子框的全选/反选状态,之后再点击母框,子框就没反应了。原代码大致结构关键如下:

function selectAll(obj){
                $(‘input[name="xxx[]"]‘).attr("checked",obj.checked);
}

<input type="checkbox" id="mother" name="mother" onclick="selectAll(this);"/>全选

<input type="checkbox" id="son1" name="xxx[]" />子框
<input type="checkbox" id="son2" name="xxx[]" />子框
<input type="checkbox" id="son3" name="xxx[]" />子框
<input type="checkbox" id="son4" name="xxx[]" />子框
 

  步骤一.尝试正面刚一波:

function selectAll(obj){
            if(obj.checked) {
                $(‘input[name="xxx[]"]‘).attr("checked", true);
            } else {
                $(‘input[name="xxx[]"]‘).removeAttr("checked");
            }
}

  卒-----完全没有效果,弃之。

  步骤二.快速上网搜索一番,发现这个问题比较常见,在遇到过这个问题的人里,我应该排在千里之外了。点开几个看了,基本都是说用prop替代attr便能解决,奈何如下:

技术分享

  然而项目上用的版本低于1.6并被告知最好不要更改版本,同弃之。

  步骤三.无可奈何,JQuery弃之...尝试改用原生js写法,代码如下:

function selectAll(obj){
    var xxx = document.getElementsByName("xxx[]");
        if(obj.checked) {
            for(var i = 0;i < xxx.length;i++) {
                xxx[i].checked = true;
            }
        } else {
            for(var i = 0;i < xxx.length;i++) {
                xxx[i].checked = false;
            }
        }
}

  测试一下,顺利解决。其实也算是个小问题,不过给了我一些启示,不能局限在一个框里,多换个角度思考问题,往往能更好地去解决问题。

 

以上是关于关于JQuery全选/反选第二次失效的问题的主要内容,如果未能解决你的问题,请参考以下文章

JQuery操作CheckBox 第二次无法选中的问题

jquery版本的问题造成第二次全选无效

attr全选第三次失效

关于jquery全选反选 批量删除的一点心得

Jquery 复选框全选与反选点击执行一次然后失效解决方案

jQuery 全选与不全选 Jquery each