解决jquery操作checkbox全选全不选无法勾选问题

Posted 喻一凡

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解决jquery操作checkbox全选全不选无法勾选问题相关的知识,希望对你有一定的参考价值。

最近在学习中使用jquery操作checkbox,使用下面方法进行全选、反选:
$("input[name=‘checkbox‘]").attr("checked","checked");
调试时,前两次都没有问题,可以正常显示选中和取消,但当再去选中的时候,复选框的属性checkbox值变为"checked",没问题,但是复选框却不在显示选中状态,明明属性值改了,但是却不显示勾选,太诡异了。代码修改了却得不到正确的显示状态,纠结了很久,找不到原因。

于是乎各种找原因,后来在网上搜到一篇文章提醒了我,原来是jQuery版本问题。
我操作属性用的是 
$("XXX").attr("attrName");而jQuery的版本用的是2.1.4,这就是存在一个兼容性和稳定性问题。 
jQuery API明确说明,1.6+的jQuery要用prop,尤其是checkBox的checked的属性的判断,即 
使用代码如下:

$("input[name=‘checkbox‘]").prop("checked"); 
$("input[name=‘checkbox‘]").prop("disabled", false); 
$("input[name=‘checkbox‘]").prop("checked", true); 

于是乎将attr改为prop,问题得解。 

以上是关于解决jquery操作checkbox全选全不选无法勾选问题的主要内容,如果未能解决你的问题,请参考以下文章

jQuery全选全不选反选

利用jQuery实现全选全不选反选(checkBox)

jQuery js实现checkbox复选框全选全不选反选 PHP

jQuery实现复选框全选全不选

jQuery实现复选框全选全不选

jQuery全选全不选反选的简洁写法实例