在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()的区别的更多相关文章

  1. jquery中attr和prop的区别、 什么时候用 attr 什么时候用 prop (转自 芈老头 )

    jquery中attr和prop的区别. 什么时候用 attr 什么时候用 prop   在高版本的jquery引入prop方法后,什么时候该用prop?什么时候用attr?它们两个之间有什么区别?这 ...

  2. jQuery中.attr()和.prop()的区别

    之前学习jQuery的时候,学习到了两种取得标签的属性值的方法:一种是elemJobj.attr(),另一种是elemJobj.prop().而在学习JS的时候,只有一种方法elemObj.getAt ...

  3. jquery中attr和prop的区别(转)

    在网络上看到这样一篇关于jquery中attr和prop的区别文章,觉得不错,所以转载了. 在jQuery 1.6中,.attr()方法查询那些没有设置的属性,则会返回一个undefined.如果你要 ...

  4. jquery中attr和prop的区别分析

    这篇文章主要介绍了jquery中attr和prop的区别分析的相关资料,需要的朋友可以参考下 在高版本的jquery引入prop方法后,什么时候该用prop?什么时候用attr?它们两个之间有什么区别 ...

  5. Jquery学习笔记(6)--jquery中attr和prop的区别【精辟】

    jquery中attr和prop的区别 在高版本的jquery引入prop方法后,什么时候该用prop?什么时候用attr?它们两个之间有什么区别?这些问题就出现了. 关于它们两个的区别,网上的答案很 ...

  6. Jquery中attr 和 prop的区别和联系

    昨天在选择借款方类型的时候总是会出现选择要点两次的现象,比如点击公司,第一次点击选择公司,没有选中,必须在次点击才可以选中,总感觉是有点延迟加载的意思,后来审查元素, 发现是redio元素,这样的话就 ...

  7. jquery中attr与prop的区别

    先从一个老生常谈的问题说起,使用jquery实现全选全不选.楼主先使用的jquery版本是 jquery-1.11.1.min.js 全选<input type="checkbox&q ...

  8. jQuery中 attr和Prop的区别

    出自这里: http://www.365mini.com/page/jquery_noconflict.htm 在jQuery中,attr()函数和prop()函数都用于设置或获取指定的属性,它们的参 ...

  9. jquery 中 attr 和 prop 的区别

    问题:在jQuery引入prop方法后,什么时候使用attr,什么时候使用prop,两者区别. 判断: 对于HTML元素本身所有的固有属性,在处理的时候,使用prop方法 对于HTML元素后来我们自己 ...

随机推荐

  1. django执行原生sql

    一.ORM row()方法:只能实现查询 d_list = models.Article.objects.raw( 'select nid, count(nid) as num,strftime(&q ...

  2. GUI学习之七——单选框QRadioButton和QButtonGroup的学习总结

    一.单选框QRadioButton的使用 1.类的描述 a.单选框按钮用于给用户提供若干选项中的单选操作,当一个被选中时,会自动取消选中的那个.(如果只有一个时可以通过单击该按钮改变其状态:而存在多个 ...

  3. Python之路(第三十六篇)并发编程:进程、同步异步、阻塞非阻塞

    一.理论基础 进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一.操作系统的其他所有内容都是围绕进程的概念展开的. 即使可以利用的cpu只有一个(早期的 ...

  4. Handler processing failed; nested exception is java.lang.NoSuchMethodError: org.apache.commons.codec.digest.DigestUtils.sha1Hex(Ljava/lang/String;)Ljava/lang/String;

    异常:Handler processing failed; nested exception is java.lang.NoSuchMethodError: org.apache.commons.co ...

  5. skyline开发——加载Shapefile文件

    //1)获取道路的GroupID string dlId = ptm.FindGroupByName("道路"); IFeatureLayer66 featureLayer = n ...

  6. Python中的迭代器、生成器

    from collections import Iterable, Iterator 1. 可迭代(iterable)对象 参考官网链接 class I: def __init__(self, v): ...

  7. sql server 临时库文件太大 迁移tempdb数据库

    由于装SQL Server时默认装在系统盘,使用一段时间后,tempdb数据库占了68G,导致整个C盘爆满,彻底解决办法就是迁移tempdb物理文件,移至其他大空间磁盘上. 将 tempdb 从其在磁 ...

  8. Koa源码分析(二) -- co的实现

    Abstract 本系列是关于Koa框架的文章,目前关注版本是Koa v1.主要分为以下几个方面: Koa源码分析(一) -- generator Koa源码分析(二) -- co的实现 Koa源码分 ...

  9. C语言内存四区的学习总结(三)---- 栈区

    接上篇内存四区的堆区的总结,下面做一些栈区的相关总结. 一.栈区的分析: 就下面测试程序 #include "stdio.h" #include "string.h&qu ...

  10. promise和生成器的结合

    if(Promise.wrap){ Promise.wrap = function(fn){ return function(){ var args = [].slice.call(arguments ...