当前位置: 移动技术网 > IT编程>开发语言>JavaScript > jquery无法设置checkbox选中即没有变成选中状态

jquery无法设置checkbox选中即没有变成选中状态

2019年03月22日  | 移动技术网IT编程  | 我要评论

代码如下:


$("input").attr("checked","checked")


设置以后checkbox并没有变成选中状态,用chrome调试看了一下,checkbox中确实有checked属性,而且,值为checked,但是页面显示仍然为未选中状态

. 代码如下:


$("input").prop("checked",true);



ttributes和properties之间的差异在特定情况下是很重要。jquery 1.6之前 ,.attr()方法在取某些 attribute 的值时,会返回 property 的值,这就导致了结果的不一致。从 jquery 1.6 开始, .prop()方法 方法返回 property 的值,而 .attr() 方法返回 attributes 的值。

例如, selectedindex, tagname, nodename, nodetype, ownerdocument, defaultchecked, 和 defaultselected 应使用.prop()方法进行取值或赋值。 在jquery1.6之前,这些属性使用.attr()方法取得,但是这并不是元素的attr属性。他们没有相应的属性(attributes),只有特性(property)。

例如,考虑一个dom元素的html标记中定义的<input type="checkbox" checked="checked" /> ,并假设它是一个javascript变量命名的elem :

elem.checked true (boolean) 将改变复选框的状态
$(elem).prop("checked") true (boolean) 将改变复选框的状态
elem.getattribute("checked") "checked" (string) 不会改变的复选框的初始状态;
$(elem).attr("checked") (1.6) "checked" (string) 不会改变的复选框的初始状态;
$(elem).attr("checked") (1.6.1+) "checked" (string) 将改变复选框的状态
$(elem).attr("checked") (pre-1.6) true (boolean) 将改变复选框的状态
根据w3c的表单规范 ,在checked属性是一个布尔属性,这意味着只要该 attribute 存在,即使它没有值,或是一个空字符串,该属性对应的 property 就是 true。以下推荐的是兼容方式,判断 checkbox 元素的 checked 属性是否为"真" 的方法:

. 代码如下:


if ( elem.checked )
if ( $(elem).prop("checked") )
if ( $(elem).is(":checked") )


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

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网