2012年11月1日更新
我最初的答案特别适用于jQuery1.6。我的建议保持不变,但jQuery 1.6.1稍微改变了一些事情:面对预测的一堆破碎的网站,jQuery团队将attr()恢复到了接近(但不完全相同)其布尔属性的旧行为。John Resig也在博客中谈到了这一点。我可以看到他们遇到的困难,但仍然不同意他的建议,更喜欢attr()。
原答覆
如果您只使用过jQuery,而没有直接使用过DOM,那么这可能是一个令人困惑的变化,尽管这在概念上肯定是一个改进。不过,对于使用jQuery的大量网站来说,这并不太好,因为这一变化会导致网站崩溃。
我将总结主要问题:
通常需要prop()而不是attr()。在大多数情况下,prop()执行attr()以前的操作。在代码中用prop(()替换对attr(的调用通常是有效的。财产通常比属性更容易处理。属性值只能是字符串,而属性可以是任何类型。例如,选中的属性是布尔值,样式属性是每个样式都有单独财产的对象,大小属性是数字。如果同时存在具有相同名称的属性和属性,通常更新一个属性会更新另一个属性,但输入的某些属性(例如value和checked)并非如此:对于这些属性,属性始终表示当前状态,而属性(旧版本的IE除外)对应于输入的默认值/检查(反映在defaultValue/defaultChecked属性中)。这一更改删除了一些停留在属性和财产前面的神奇jQuery层,这意味着jQuery开发人员必须了解财产和属性之间的区别。这是一件好事。
如果您是一名jQuery开发人员,对财产和属性的整个业务感到困惑,那么您需要后退一步,稍微了解一下,因为jQuery不再试图保护您不受这些东西的影响。关于这个主题的权威但有些枯燥的词汇,有一些规范:DOM4、HTMLDOM、DOMLevel 2、DOMLevel 3。Mozilla的DOM文档适用于大多数现代浏览器,并且比规范更容易阅读,因此您可能会发现它们的DOM参考很有用。有一节是关于元素财产的。
作为财产比属性更容易处理的示例,请考虑一个最初选中的复选框。这里有两种可能的有效HTML:
<input id="cb" type="checkbox" checked>
<input id="cb" type="checkbox" checked="checked">
那么,如何确定jQuery是否选中了复选框?查看堆栈溢出,您通常会发现以下建议:
如果($(“#cb”).attr(“checked”)==true){…}如果($(“#cb”).attr(“check”)==“checked”){…}如果($(“#cb”).is(“:checked”)){…}
这实际上是世界上使用选中的布尔属性最简单的事情,自1995年以来,它在每个主要的可脚本化浏览器中都存在并完美运行:
if(document.getElementById(“cb”).checked){…}
该属性还使选中或取消选中复选框变得微不足道:
document.getElementById(“cb”).checked=false
在jQuery1.6中,这明确地变成
$(“#cb”).prop(“checked”,false)
使用checked属性编写复选框脚本的想法是无益的,也是不必要的。这是你需要的。
使用checked属性来检查或取消选中复选框的正确方法并不明显属性值反映的是默认状态,而不是当前的可见状态(除了在一些旧版本的IE中,这使得事情变得更加困难)。属性告诉页面上的复选框是否被选中。看见http://jsfiddle.net/VktA6/49/.