所以jQuery1.6有了新的函数prop()。

$(selector).click(function(){
    //instead of:
    this.getAttribute('style');
    //do i use:
    $(this).prop('style');
    //or:
    $(this).attr('style');
})

或者在这种情况下,他们会做同样的事情吗?

如果我必须切换到使用prop(),那么如果我切换到1.6,所有旧的attr()调用都会中断?

更新

选择器='#id'$(选择器).click(函数){//而不是:var getAtt=this.getAttribute('style');//我是否使用:var thisProp=$(this).prop('style');//或:var thisAttr=$(this).attr(“样式”);console.log(getAtt、thisProp、thisAttr);});<script src=“https://ajax.googleapis.com/ajax/libs/jquery/1.6.0/jquery.min.js“></script>测试</div>

(另请参见此小提琴:http://jsfiddle.net/maniator/JpUF2/)

控制台将getAttribute作为字符串记录,将attr作为字符串记录但将prop作为CSSStyleDeclaration记录,为什么?这对我未来的编码有何影响?


当前回答

在jQuery1.6之前,attr()方法在检索属性时有时会考虑属性值,这会导致相当不一致的行为。

prop()方法的引入提供了一种显式检索属性值的方法,而.attr()检索属性。

文件:

jQuery.attr()获取匹配元素集合中第一个元素的属性值。

jQuery.prop()获取匹配元素集合中第一个元素的属性值。

其他回答

.attr():

获取匹配元素集合中第一个元素的属性值。为您提供页面加载时html中定义的元素值

.prop():

获取匹配元素集合中第一个元素的属性值。提供通过javascript/jquery修改的元素的更新值

通常你会想使用财产。仅将属性用于:

获取自定义HTML属性(因为它未与DOM属性同步)。获取与DOM属性不同步的HTML属性,例如获取标准HTML属性的“原始值”,如<input value=“abc”>。

所有内容都在文档中:

属性和财产之间的差异在特定情况下可能很重要。在jQuery1.6之前,.attr()方法在检索某些属性时有时会考虑属性值,这可能会导致不一致的行为。从jQuery1.6开始,.prop()方法提供了显式检索属性值的方法,.attr()方法检索属性。

所以使用道具!

对于jQuery来说,这一变化已经发生了很长时间。多年来,他们一直满足于一个名为attr()的函数,该函数主要检索DOM财产,而不是您期望从名称中得到的结果。attr()和prop()的分离应该有助于缓解HTML属性和DOM财产.$之间的一些混淆。fn.prop()获取指定的DOM属性,而$.fn.attr()获取特定的HTML属性。

为了充分理解它们的工作原理,这里有一个关于HTML属性和DOM财产之间差异的扩展解释

HTML属性

语法:

<body onload=“foo()”>

目的:允许标记将数据与之关联,以用于事件、渲染和其他目的。

可视化:class属性显示在正文中。可以通过以下代码访问:

var attr;
attr = document.body.getAttribute("class");
//IE 8 Quirks and below
attr = document.body.getAttribute("className");

属性以字符串形式返回,并且在浏览器之间可能不一致。然而,它们在某些情况下可能至关重要。如上所述,IE8QuirksMode(及以下)期望get/set/removeAttribute中的DOM属性名称,而不是属性名称。这是了解差异很重要的众多原因之一。

DOM财产

语法:

document.body.onload=foo;

目的:允许访问属于元素节点的财产。这些财产类似于属性,但只能通过JavaScript访问。这是一个重要的区别,有助于阐明DOM财产的作用。请注意,属性与财产完全不同,因为此事件处理程序分配没有用处,不会接收事件(正文没有onload事件,只有onload属性)。

可视化:

在这里,您会注意到Firebug中“DOM”选项卡下的财产列表。这些是DOM财产。你会立即注意到其中的很多,因为你以前会在不知道的情况下使用它们。它们的值就是你通过JavaScript收到的值。

文档

JavaScript:最终指南大卫·福莱纳根HTML属性,Mozilla开发中心Mozilla开发中心DOM元素财产

实例

HTML:<textarea id=“test”value=“foo”></textarea>

JavaScript:警报($('#test').attr('value'));

在早期版本的jQuery中,这将返回一个空字符串。在1.6中,它返回正确的值foo。

在没有浏览过这两个函数的新代码的情况下,我可以自信地说,混淆更多的是与HTML属性和DOM财产之间的差异有关,而不是与代码本身有关。希望这能帮你解决一些问题。

-马特

在prop()与attr()中,几乎没有其他注意事项:

selectedIndex、tagName、nodeName、nodeType、ownerDocument、defaultChecked和defaultSelected。。应使用.prop()方法检索和设置。这些属性没有相应的属性,只是财产。输入类型复选框.attr('checked')//返回已检查.prop('checked')//返回true.is(“:checked”)//返回trueprop方法返回选中、选中、禁用或禁用的布尔值,只读。。而attr返回定义的字符串。所以,你可以直接在if条件下使用.prop('checked')。.attr()在内部调用.prop(),因此.attr比直接通过.prop()访问它们慢。