点击checkbox后,$(this).attr('checked')得到的值不会发生改变

Posted linqingvoe

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了点击checkbox后,$(this).attr('checked')得到的值不会发生改变相关的知识,希望对你有一定的参考价值。

 这两天遇到一个问题,就是在点击checkbox后,$(this).attr(‘checked‘)得到的值要么是undefined,要么是checked,同一个表单一直点击却一点都不会发生改变,调试了一下,this里的checked是会改变的,说明checkbox是有正常运行的,查了很久后,最我怀疑是$(this).attr(‘checked‘)这句代码出了问题,果然往这个方向找有了收获。

    原来jquery 1.6以前用$(this).attr(‘checked‘)得到的是true/false,但到了1.6以后,$(this).attr(‘checked‘)就有点问题了。

    解决方案如下:

    1. 使用is()

        例句: $(this).is(":checked");             // 注意是‘:checked‘,有冒号的!

    2. 使用prop()方法,JQ1.6之后,可以通过attr方法去获得属性,通过prop方法去获得特性,属性指的是“name,id”等等,特性指的是“selectedIndex, tagName, nodeName”等等。 

        例句: $(this).prop(‘checked‘);

以上是关于点击checkbox后,$(this).attr('checked')得到的值不会发生改变的主要内容,如果未能解决你的问题,请参考以下文章

js中checkbox全选怎么写

checkbox 全选反选 获得所有的checkbox

input checkbox操作,最好用prop,不要用attr

jQuery 修改checkbox的状态,无效

jquery,attr,prop,checkbox标签已有checked=checked但是不显示勾选

jquery 如何选中table中的所有checkbox 求高手帮忙解答