zl程序教程

您现在的位置是:首页 >  前端

当前栏目

jquery中checkbox全选失效的解决方法

jQuery方法 解决 失效 checkbox 全选
2023-06-13 09:15:38 时间

如果你使用jQuery1.6,代码if($(elem).attr(“checked”)),将获得一个属性(attribute),它不改变该复选框被选中和选中。它只是用来存储默认或选中属性的初始值。为了保持向后兼容,.attr()方法从jQuery1.6.1+开始除了返回属性值外,还会更新property属性,因此booleanattribute(布尔属性)不需要通过.prop()来改变其值。推荐使用上述方法之一,来取得checked的值。

使用jQuery的attr方法获取和设置复选框的”checked”属性,发现第一次全选/取消全选有效,之后就无效了,但查看html源文件,复选框属性确实已经被更新了,就是页面中没有更新,正确的方法如下:

<scripttype="text/javascript"src="http://code.jquery.com/jquery-1.11.1.min.js"></script><scripttype="text/javascript">//<![CDATA[
$(function(){
$(".ckAll").click(function(){
$(".box-items").each(function(){
$(this).prop("checked",!!$(".box-all").prop("checked"));
});
});
});
//]]></script>
<div><labelclass="ckAll"><inputclass="box-all"type="checkbox"/><span>全选</span></label>
<inputclass="box-items"type="checkbox"/>
<inputclass="box-items"type="checkbox"/>
<inputclass="box-items"type="checkbox"/>
<inputclass="box-items"type="checkbox"/>
<inputclass="box-items"type="checkbox"/>
</div>