最近在项目中,遇到一个问题,测试全选/反选功能时,第一次对母框进行选中/非选中时,能同步子框的全选/反选状态,之后再点击母框,子框就没反应了。
原代码大致结构关键如下:
rush:xhtml;">
function selectAll(obj){
$('input[name="xxx[]"]').attr("checked",obj.checked);
}
<input type="checkBox" id="mother" name="mother" onclick="selectAll(this);"/>全选
子框子框子框子框步骤一:
尝试正面刚一波:rush:xhtml;">
function selectAll(obj){
if(obj.checked) {
$('input[name="xxx[]"]').attr("checked",true);
} else {
$('input[name="xxx[]"]').removeAttr("checked");
}
}
卒-----完全没有效果,弃之。
步骤二:
快速上网搜索一番,发现这个问题比较常见,在遇到过这个问题的人里,我应该排在千里之外了。点开几个看了,基本都是说用prop替代attr便能解决,奈何如下:然而项目上用的版本低于1.6并被告知最好不要更改版本,同弃之。
步骤三:
无可奈何,JQuery弃之...尝试改用原生js写法,代码如下:rush:xhtml;">
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全选/反选第二次失效的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。