原代码大致结构关键如下:
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; } } }
测试一下,顺利解决。其实也算是个小问题,不过给了我一些启示,不能局限在一个框里,多换个角度思考问题,往往能更好地去解决问题。
相关推荐:
js实现全选全不选
js复选框全选反选的方法
js实现前端全选和反选
以上就是jquery全选/反选第二次失效如何解决的详细内容。
