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

页面导航:首页 > 网络编程 > JavaScript > 解决jquery操作checkbox全选全不选无法勾选问题

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

来源: 作者: 时间:2016-01-19 18:32 【

解决jquery操作checkbox全选全不选无法勾选问题最近在工作中使用jquery操作checkbox,使用下面方法进行全选、反选:$(input[name=checkbox]) attr(checked,checked);调试时,前两次都没有问题,可以
解决jquery操作checkbox全选全不选无法勾选问题

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

于是乎各种找原因,后来在网上搜到一篇文章提醒了我,原来是jQuery版本问题。
我操作属性用的是
$(XXX).attr(attrName);而jQuery的版本用的是2.1.1,这就是存在一个兼容性和稳定性问题。
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,问题得解。
如果您遇到这个奇怪的问题那就赶紧试试吧!

 

Tags:

文章评论

最 近 更 新
热 点 排 行
Js与CSS工具
代码转换工具

<