jQuery中attr和prop方法的区别。

http://my.oschina.net/bosscheng/blog/125833

http://www.javascript100.com/?p=877

这篇讲的还好

相比attr,prop是1.6.1才新出来的,两者从中文意思理解,都是获取/设置属性的方法(attributes和properties)。只是,window或document中使用.attr()方法在jQuery1.6之前不能正常运行,因为window和document中不能有attributes。prop应运而生了。

之前看网上对比两者的文章,更是列出一个表来区分什么标签下使用prop,什么标签下使用attr,原谅我是懒惰的人,最害怕要背的东西,所以只有自己想想办法了。

既然我们想知道他们两的区别,最好就看看他们的源代码,不要被代码长度所吓到,我们只看关键的几句:

attr方法代码(jQuery版本1.8.3)

    • attr: function( elem, name, value, pass ) {
    • var ret, hooks, notxml,
    • nType = elem.nodeType;
    • // don't get/set attributes on text, comment and attribute nodes
    • if ( !elem || nType === 3 || nType === 8 || nType === 2 ) {
    • return;
    • }
    • if ( pass && jQuery.isFunction( jQuery.fn[ name ] ) ) {
    • return jQuery( elem )[ name ]( value );
    • }
    • // Fallback to prop when attributes are not supported
    • if ( typeof elem.getAttribute === "undefined" ) {
    • return jQuery.prop( elem, name, value );
    • }
    • notxml = nType !== 1 || !jQuery.isXMLDoc( elem );
    • // All attributes are lowercase
    • // Grab necessary hook if one is defined
    • if ( notxml ) {
    • name = name.toLowerCase();
    • hooks = jQuery.attrHooks[ name ] || ( rboolean.test( name ) ? boolHook : nodeHook );
    • }
    • if ( value !== undefined ) {
    • if ( value === null ) {
    • jQuery.removeAttr( elem, name );
    • return;
    • } else if ( hooks && "set" in hooks && notxml && (ret = hooks.set( elem, value, name )) !== undefined ) {
    • return ret;
    • } else {
    • elem.setAttribute( name, value + "" );
    • return value;
    • }
    • } else if ( hooks && "get" in hooks && notxml && (ret = hooks.get( elem, name )) !== null ) {
    • return ret;
    • } else {
    • ret = elem.getAttribute( name );
    • // Non-existent attributes return null, we normalize to undefined
    • return ret === null ?
    • undefined :
    • ret;
    • }
    • }

prop方法代码(jQuery版本1.8.3)

    • prop: function( elem, name, value ) {
    • var ret, hooks, notxml,
    • nType = elem.nodeType;
    • // don't get/set properties on text, comment and attribute nodes
    • if ( !elem || nType === 3 || nType === 8 || nType === 2 ) {
    • return;
    • }
    • notxml = nType !== 1 || !jQuery.isXMLDoc( elem );
    • if ( notxml ) {
    • // Fix name and attach hooks
    • name = jQuery.propFix[ name ] || name;
    • hooks = jQuery.propHooks[ name ];
    • }
    • if ( value !== undefined ) {
    • if ( hooks && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ) {
    • return ret;
    • } else {
    • return ( elem[ name ] = value );
    • }
    • } else {
    • if ( hooks && "get" in hooks && (ret = hooks.get( elem, name )) !== null ) {
    • return ret;
    • } else {
    • return elem[ name ];
    • }
    • }
    • }

attr方法里面,最关键的两行代码,elem.setAttribute( name, value + “” )和ret = elem.getAttribute( name ),很明显的看出来,使用的DOM的API setAttribute和getAttribute方法操作的属性元素节点
而prop方法里面,最关键的两行代码,return ( elem[ name ] = value )和return elem[ name ],你可以理解成这样document.getElementById(el)[name] = value,这是转化成JS对象的一个属性。

既然明白了原理是这样,我们来看看一个例子:

    • <input type="checkbox" id="test" abc="111" />
    • $(function(){
    • el = $("#test");
    • console.log(el.attr("style"));  //undefined
    • console.log(el.prop("style"));  //CSSStyleDeclaration对象
    • console.log(document.getElementById("test").style); //CSSStyleDeclaration对象
    • });
  1. el.attr(“style”)输出undefined,因为attr是获取的这个对象属性节点的值,很显然此时没有这个属性节点,自然输出undefined

  2. el.prop(“style”)输出CSSStyleDeclaration对象,对于一个DOM对象,是具有原生的style对象属性的,所以输出了style对象

  3. 至于document.getElementById(“test”).style和上面那条一样

我们接着看:

    • el.attr("abc","111")
    • console.log(el.attr("abc")); //111
    • console.log(el.prop("abc")); //undefined

首先用attr方法给这个对象添加abc节点属性,值为111,可以看到html的结构也变了

  1. el.attr(“abc”)输出结果为111,再正常不过了

  2. el.prop(“abc”)输出undefined,因为abc是在这个的属性节点中,所以通过prop是取不到的

我们再接着来:

    • el.prop("abc", "222");
    • console.log(el.attr("abc")); //111
    • console.log(el.prop("abc")); //222

我们再用prop方法给这个对象设置了abc属性,值为222,可以看到html的结构是没有变化的。输出的结果就不解释了。

上面已经把原理讲清楚了,什么时候用什么就可以自己把握了。

提一下,在遇到要获取或设置checked,selected,readonly和disabled等属性时,用prop方法显然更好,比如像下面这样:

    • <input type="checkbox" id="test" checked="checked" />
  1. text
    • console.log(el.attr("checked")); //checked
    • console.log(el.prop("checked")); //true
    • console.log(el.attr("disabled")); //undefined
    • console.log(el.prop("disabled"));  //false

显然,布尔值比字符串值让接下来的处理更合理。

PS一下,如果你有JS性能洁癖的话,显然prop的性能更高,因为attr需要访问DOM属性节点,访问DOM是最耗时的。这种情况适用于多选项全选和反选的情况。

原创文章,转载请注明: 转载自前端开发

本文链接地址: jQuery中attr和prop方法的区别

jQuery中attr和prop方法的区别的更多相关文章

  1. jQuery中attr和prop方法的区别说明

    jquery中attr和prop的基本区别可以理解为:如果是内置属性,建议用prop,如果是自定义的建议用attr. 例如 <input type=check  node=123 id=ck & ...

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

    前几天,有人给 Multiple Select 插件 提了问题: setSelects doesn't work in Firefox when using jquery 1.9.0 一直都在用 jQ ...

  3. jQuery 中 attr() 和 prop() 方法的区别<转>

    前几天,有人给 Multiple Select 插件 提了问题: setSelects doesn't work in Firefox when using jquery 1.9.0 一直都在用 jQ ...

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

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

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

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

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

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

  7. jquery中attr()与prop()函数用法实例详解(附用法区别)

    本文实例讲述了jQuery中attr()与prop()函数用法.分享给大家供大家参考,具体如下: 一.jQuery的attr()方法 jquery中用attr()方法来获取和设置元素属性,attr是a ...

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

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

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

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

随机推荐

  1. COPY, RETAIN, ASSIGN , READONLY , READWRITE,STRONG,WEAK,NONATOMIC整理--转

    copy:建立一个索引计数为1的对象,然后释放旧对象 对NSString 对NSString 它指出,在赋值时使用传入值的一份拷贝.拷贝工作由copy方法执行,此属性只对那些实行了NSCopying协 ...

  2. Keepalived+Nginx实现Nginx的高可用

    集群规划 主机名 IP VIP Nginx:port KeepAlived主备 KA_NG_01 192.168.30.130 192.168.30.120 8088 MASTER KA_NG_02 ...

  3. Ionic之增加样式会自动换行解决方案

    设置样式的时候,引用自身的样式,能正常显示,但是引用自定义样式显示的时候,竟然或自动换行,好尴尬. 原本代码: $('.codeSuccess').css({'display':'block'}); ...

  4. 【转】JobScheduler

    JobScheduler JobScheduler是Android L(API21)新增的特性,用于定义满足某些条件下执行的任务.它的宗旨是把一些不是特别紧急的任务放到更合适的时机批量处理,这样可以有 ...

  5. flex和box兼容性写法

    display: -webkit-box; /* Chrome 4+, Safari 3.1, iOS Safari 3.2+ */ display: -moz-box; /* Firefox 17- ...

  6. spring mvc 解决 Could not open ServletContext resource [/WEB-INF/dispatcher-servlet.xml] 异常

    org.springframework.beans.factory.BeanDefinitionStoreException: IOException parsing XML document fro ...

  7. 借助tween.js小球沿div四边跑的动画效果

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  8. HDU 5381 The sum of gcd (技巧,莫队算法)

    题意:有一个含n个元素的序列,接下来有q个询问区间,对每个询问区间输出其 f(L,R) 值. 思路: 天真单纯地以为是道超级水题,不管多少个询问,计算量顶多就是O(n2) ,就是暴力穷举每个区间,再直 ...

  9. [转] 学习,思维三部曲:WHAT、HOW、WHY(通过现象看本质)

    https://www.douban.com/note/284947308/?type=like 学习技术的三部曲:WHAT HOW WHY 我把学习归类为三个步骤:What.How.Why.经过我对 ...

  10. 在Eclipse中通过JDBC连接MySQL步骤,非常详细!

    通过JDBC连接MySQL基本步骤代码讲解步骤可能遇到的Bug基本步骤JDBC访问MySQL 1.加载JDBC驱动器—>哪个project需要,就添加到该project的jdbc文件夹下,我的j ...