Jquery中attr()与prop()的区别
在jQuery中,attr()函数和prop()函数都用于设置或获取指定的属性,它们的参数和用法也几乎完全相同。但是,这两个函数的用处却并不相同。下面我们来详细介绍这两个函数之间的区别。
1、操作对象不同
attr是单词attribute的缩写,prop是property的缩写,它们的都表示”属性”的意思。不过,在Jquery里面attribute和property是两个不同的概念。attribute表示HTML文档节点的属性,property表示JS对象的属性。
我们来看个例子区分一下什么是HTML文档节点的属性和JS对象的属性:

2、应用版本不同
attr()是JQuery 1.0版本就有的函数,prop()是JQuery 1.6版本新增加的函数。也就是说,在JQuery 1.6版本之前,只能使用attr()函数。在JQuery 1.6版本后,可以根据不同的需求来选择使用的函数。
在JQuery 1.6版本之前,attr()函数不仅要对attribute进行设置和获取,还要对property进行设置和获取。在1.6版本之前,attr()可以设置和获取tagName、className、nodeName、nodeType等DOM元素的property。后来1.6版本之后出现了prop函数,可以通过它来对property进行获取和设置,attr()函数才只用来对attribute的进行设置和获取。
但是从1.6开始,使用attr()获取这些属性的返回值为String类型,如果被选中(或禁用)就返回checked、selected或disabled,否则(即元素节点没有该属性)返回undefined。并且,在某些版本中,这些属性值表示文档加载时的初始状态值,即使之后更改了这些元素的选中(或禁用)状态,对应的属性值也不会发生改变。
因为jQuery认为:attribute的checked、selected、disabled就是表示该属性初始状态的值,property的checked、selected、disabled才表示该属性实时状态的值(值为true或false)。
因此,在jQuery 1.6及以后版本中,请使用prop()函数来设置或获取checked、selected、disabled等属性。对于其它能够用prop()实现的操作,也尽量使用prop()函数。
3、设置属性值的类型不同
由于attr()函数操作的是文档节点的属性,因此设置的属性值只能是字符串类型,如果不是字符串类型,也会调用其toString()方法,将其转为字符串类型。
prop()函数操作的是JS对象的属性,因此设置的属性值可以为包括数组和对象在内的任意类型。
总结:
对于HTML元素本身就带有的固有属性,例如:id、name等属性,使用prop()函数。
对于HTML元素自定义的DOM属性,使用attr()函数。
返回值是true/false的属性,建议使用prop()
下面我们举例子解释一下:
"div1" class="class1">
在例子中
元素的DOM属性有”id、class”,这些属性就是
属性自带的属性,我们可以去参考W3C标准里包含的一些属性,这些属性就是固有属性。处理这些属性的时候我们就用prop()函数。
"div1" class="class1" data_id="1">
这里的例子,固有属性是”id、class”,然后又自定义了一个”data_id”的属性,
元素本身就没有这个属性的,这种就是自定义的DOM属性。处理这种属性时,就用attr()函数。如果使用了prop()函数去获取或设置值时,会返回undefinded。
我们再来看一个属性值返回true和false的例子:
"chk1" type="checkbox" />
"chk2" type="checkbox" checked="checked" />
checkbox、radio和select这三个元素,选中的属性对应的是”checked、checked和selected”,这些也是固有属性,因此我们尽量用prop()函数去处理。在1.6版本后,attr()获取的值返回的都是字符串,因此用attr()去获取返回值是true/false的属性,返回值是undefinded。
使用prop()函数返回的结果:
console.log($("#chk1").prop("checked")); // false
console.log($("#chk2").prop("checked")); // true

使用attr()函数返回的结果:

console.log($("#chk1").attr("checked")); // undefined
console.log($("#chk2").attr("checked")); // checked
上海尚学堂java原作,欢迎阅读上海尚学堂更多java技术相关文章,转载请说明出处。获取更多资料或支持请加薇 java8733
Jquery中attr()与prop()的区别的更多相关文章
- jquery中attr和prop的区别、 什么时候用 attr 什么时候用 prop (转自 芈老头 )
jquery中attr和prop的区别. 什么时候用 attr 什么时候用 prop 在高版本的jquery引入prop方法后,什么时候该用prop?什么时候用attr?它们两个之间有什么区别?这 ...
- jQuery中.attr()和.prop()的区别
之前学习jQuery的时候,学习到了两种取得标签的属性值的方法:一种是elemJobj.attr(),另一种是elemJobj.prop().而在学习JS的时候,只有一种方法elemObj.getAt ...
- jquery中attr和prop的区别(转)
在网络上看到这样一篇关于jquery中attr和prop的区别文章,觉得不错,所以转载了. 在jQuery 1.6中,.attr()方法查询那些没有设置的属性,则会返回一个undefined.如果你要 ...
- jquery中attr和prop的区别分析
这篇文章主要介绍了jquery中attr和prop的区别分析的相关资料,需要的朋友可以参考下 在高版本的jquery引入prop方法后,什么时候该用prop?什么时候用attr?它们两个之间有什么区别 ...
- Jquery学习笔记(6)--jquery中attr和prop的区别【精辟】
jquery中attr和prop的区别 在高版本的jquery引入prop方法后,什么时候该用prop?什么时候用attr?它们两个之间有什么区别?这些问题就出现了. 关于它们两个的区别,网上的答案很 ...
- Jquery中attr 和 prop的区别和联系
昨天在选择借款方类型的时候总是会出现选择要点两次的现象,比如点击公司,第一次点击选择公司,没有选中,必须在次点击才可以选中,总感觉是有点延迟加载的意思,后来审查元素, 发现是redio元素,这样的话就 ...
- jquery中attr与prop的区别
先从一个老生常谈的问题说起,使用jquery实现全选全不选.楼主先使用的jquery版本是 jquery-1.11.1.min.js 全选<input type="checkbox&q ...
- jQuery中 attr和Prop的区别
出自这里: http://www.365mini.com/page/jquery_noconflict.htm 在jQuery中,attr()函数和prop()函数都用于设置或获取指定的属性,它们的参 ...
- jquery 中 attr 和 prop 的区别
问题:在jQuery引入prop方法后,什么时候使用attr,什么时候使用prop,两者区别. 判断: 对于HTML元素本身所有的固有属性,在处理的时候,使用prop方法 对于HTML元素后来我们自己 ...
随机推荐
- JavaSE基础知识(5)—面向对象(Object类)
一.包 java.lang包,属于java中的核心包,系统默认导入的,不用手动导入该包中的类:Object.System.String.Integer等 1.包的好处 ①分类管理java文件,查找和管 ...
- django admin的实用配置
https://www.cnblogs.com/wumingxiaoyao/p/6928297.html
- docker构建镜像
Docker 提供了两种构建镜像的方法: docker commit 命令Dockerfile 构建文件 示例: Dockerfile FROM golang:1.7.5 #基础镜像 RUN apt- ...
- Reveal Cards In Increasing Order LT950
In a deck of cards, every card has a unique integer. You can order the deck in any order you want. ...
- laravel-更换语言包
第一步:找语言包 找到比较靠谱的语言包(根据下载量与收藏量综合判断),而且要是laravel的 扩展的链接:https://packagist.org/packages/caouecs/laravel ...
- PHP基础(命名错误)错误导致的500
记得去年七月份参与一个项目发生的一个低级错误 因为不小心在命名一个方法时使用了一list做为名称,因此在后面无明业火被点燃. 发现一个500,无论如何调整总是500,数据库,文件,url都正确,但就是 ...
- Quartz错过任务执行时间的处理机制(Misfire处理规则 )
调度(scheduleJob)或恢复调度(resumeTrigger,resumeJob)后不同的misfire对应的处理规则 CronTrigger withMisfireHandlingInstr ...
- Chapter5_初始化与清理_成员初始化
在java中,成员初始化在使用之前应该都要保证已经完成初始化.对于在方法体中的局部变量,如果没有使用指定初始化的方法对成员变量进行初始化,编译器会提示一个错误.而对于类的数据成员,编译器会对这些成员赋 ...
- 移动端常见bug
meta基础知识 H5页面窗口自动调整到设备宽度,并禁止用户缩放页面 <meta name="viewport" content="width=device-wid ...
- 通过TensorFlow训练神经网络模型
神经网络模型的训练过程其实质上就是神经网络参数的设置过程 在神经网络优化算法中最常用的方法是反向传播算法,下图是反向传播算法流程图: 从上图可知,反向传播算法实现了一个迭代的过程,在每次迭代的开始,先 ...