您好,欢迎来到刀刀网。
搜索
您的当前位置:首页关于JQuery全选/反选第二次失效的问题

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

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


'input[name="xxx[]"]').attr("checked"

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


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;
 }
 }
}

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

Copyright © 2019- gamedaodao.com 版权所有 湘ICP备2022005869号-6

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务