jQuery 全选与反选时出现的bug! 回复送分!

J2eeFans 2014-06-08 08:54:25
今天在写项目,使用jQuery1.10.2 发现一个小小的bug, 在设置checked属性时,前两次反选的时候是正常的,后面均不正确,通过调试,
准确的说应该是只有第一次是正确的,在第二次单击时,事件快完成的时候的运行的流程有点奇怪。所以自己感觉这么
成熟的框架不应该出现这个问题,于是又将1.11.1版本下载下来,也是jQuery1的最新版本测试,同样末果,问题依
然存在,使用标准的document.getElementById, 直接设置值是没有问题的。

我本人根据测试,应该是jQuery的一个bug,不知道是不是我的代码有问题。

代码如下:请高手请指教,非常感谢!


[javascript] view plaincopy在CODE上查看代码片派生到我的代码片

function unSelect(id, name) {
var ckBoxs = document.getElementsByName(name);
var count = 0;
for ( var i = 0; i < ckBoxs.length; i++) {
if (ckBoxs[i].checked == true) {
ckBoxs[i].checked = false;
} else {
ckBoxs[i].checked = true;
count ++;
}
}

/*
jQuery1.10.2 一个小小的bug, 在设置checked属性时,前两次反选的时候是正常的,后面均不正确,通过调试,准确的说应该是只有第一次是正确的,在第二次单击时,事件快完成的时候的运行的流程有点奇怪。
所以自己感觉这么成熟的框架不应该出现这个问题,于是又将1.11.1版本下载下来,也是jQuery1的最新版本测试,同样末果,问题依然存在,使用标准的document.getElementById, 直接设置值是没有问题的。
希望这个问题能及时解决。谢谢。
*/
if(count == ckBoxs.length) {
document.getElementById(id).checked = true;
//$("#"+id).attr("checked", true);
} else {
document.getElementById(id).checked = false;
//$("#"+id).attr("checked", false);
}
}
...全文
804 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
baidu_31891653 2015-11-16
  • 打赏
  • 举报
回复
遇到同样的问题了 我也觉得是版本兼容没处理好哈
qq328348253 2014-06-10
  • 打赏
  • 举报
回复
新手学习学习,留名取分。
gxhxxx 2014-06-09
  • 打赏
  • 举报
回复
引用 1 楼 zyl_lyr1019 的回复:
这个时很常见的啊,就是attr和prop的差别所在,或者也可以说是,属性值和状态值得差别了。 你把attr改成prop就可以了。 请参考:jquery中attr方法和prop方法的区别
正解
qq137051908 2014-06-09
  • 打赏
  • 举报
回复
prop正解
xuzuning 2014-06-08
  • 打赏
  • 举报
回复
<script src=scripts/jquery-1.11.0.min.js></script>
<script>
$(function() {
  $('#all').click(function() {
    $(':checkbox').attr("checked", $(this).prop("checked"));
  });
});
</script>
<input type=checkbox id=all>
<input type=checkbox>
<input type=checkbox>
<input type=checkbox>
zhjdg 2014-06-08
  • 打赏
  • 举报
回复
是setAttribute 的事。
天际的海浪 2014-06-08
  • 打赏
  • 举报
回复
用.prop("checked",true)
张运领 2014-06-08
  • 打赏
  • 举报
回复
这个时很常见的啊,就是attr和prop的差别所在,或者也可以说是,属性值和状态值得差别了。 你把attr改成prop就可以了。 请参考:jquery中attr方法和prop方法的区别

87,922

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧