jquery中attr()和prop()的区别 - Go语言中文社区

jquery中attr()和prop()的区别


我理解的jquery中attr()和prop()的区别

查了很多资料,官方解释如下:

– attr() 方法设置或返回被选元素的属性和值。
– prop() 方法设置或返回被选元素的属性和值。

???此处自动脑补黑人问号脸!!!我真的不理解啊!!!有区别吗这两句话?!
还有一句解释:

注意:prop() 方法应该用于检索属性值,例如 DOM 属性(如 selectedIndex, tagName, nodeName, nodeType, ownerDocument, defaultChecked, 和 defaultSelected)。
提示:如需检索 HTML 属性,请使用 attr() 方法代替。

然后给了一个例子,大概明白了一点点:

attr()返回的是“属性”的值,就是能在html中看到的属性,如:

<input id="check1" type="checkbox"  >
$("input").attr('checked')	#undefined

<input id="check1" type="checkbox" checked="checked" >
$("input").attr('checked')	#checked

prop()返回的是JS对象属性的“值”,只能看到属性的值(true,false),如:

<input id="check1" type="checkbox"  >
$("input").prop('checked')	#false

<input id="check1" type="checkbox" checked="checked" >
$("input").prop('checked')	#true

以下为文档https://segmentfault.com/a/1190000002680303中的引用,说的很详细

★★★★★
对于表单元素的checked、selected、disabled等属性,在jQuery 1.6之前,attr()获取这些属性的返回值为Boolean类型:如果被选中(或禁用)就返回true,否则返回false。
★★★★★
但是从1.6开始,使用attr()获取这些属性的返回值为String类型,如果被选中(或禁用)就返回checked、selected或disabled,否则(即元素节点没有该属性)返回undefined。并且,在某些版本中,这些属性值表示文档加载时的初始状态值,即使之后更改了这些元素的选中(或禁用)状态,对应的属性值也不会发生改变。
因为jQuery认为:attribute的checked、selected、disabled就是表示该属性初始状态的值,property的checked、selected、disabled才表示该属性实时状态的值(值为true或false)。

因此,在jQuery1.6及以后版本中,请使用prop()函数来设置或获取checked、selected、disabled等属性。对于其它能够用prop()实现的操作,也尽量使用prop()函数。

综上,我的问题就是因为我要增加一个class并且让按钮失效后无法点击,给html设置了一个disabled属性,使用prop()会导致设置的值实际上是true,而使用attr()才能保证设置的值是html属性中的disabled
以下分别是我使用attr()和prop()设置属性的html属性值展示结果:
attr()
attr("disabled",true)
prop()
prop("disabled",true)

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/Chloe_Yang/article/details/89206537
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2020-03-01 23:06:04
  • 阅读 ( 1103 )
  • 分类:前端

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢