之前学习jQuery的时候,学习到了两种取得标签的属性值的方法:一种是elemJobj.attr(),另一种是elemJobj.prop()。而在学习JS的时候,只有一种方法elemObj.getAttribute()。刚开始知道这两个jQuery方法都可以取得元素的属性值的时候,我觉得很奇怪,以为随着jQuery版本更新造成的历史遗留方法,所以花时间查了查attribute和property的区别,发现原来这两个其实是有区别的。其间我主要参考了这两篇文章:

JavaScript中的property和attribute介绍--脚本之家

jquery中attr和prop的区别--〖芈老头〗的技术空间

  • property

property是元素的固有属性,本身就拥有的,是写在HTML标准里的元素的属性。

  • attribute

attribute是我们自己定义的元素的属性,是没写在HTML标注中的,而是我们需要的时候自己进行定义的。

在了解了这两点的前提下,就可以对jQuery里的这两种方法的区别进行探讨了。对于元素本身固有的属性,我们应该用elemJobj.prop()方法进行取值,这样才能得到所需属性的正确值/计算值,特别在"值不是字符串类型而是布尔型"并且"采用简写形式的属性"时,如果采用.attr()方法,将得到undefined,而不是属性的布尔值。而采用elemJobj.attr()方法,我们会获得属性的字面量。

引用〖芈老头〗老师的例子:

  1. <input id="input1" type="checkbox">
  2. <input id="input2" type="checkbox" checked="checked">

在这个例子中,如果使用elemJobj.prop()方法,会得到如下结果:

  1. $("#input1").prop("checked"); //false
  2. $("#input2").prop("checked"); //true

而如果使用elemJobj.attr()方法,会得到如下结果:

  1. $("#input1").attr("checked"); //undefined
  2. $("#input2").attr("checked"); //checked
  3. //补充说明:如果input2的checked属性是简写的形式,结果也与上面测试的结果是一样的,因为浏览器会给简写形式默认的值

由此可见,读取固有属性,应该使用.prop()方法,而不该使用.attr()方法。相对应地,读取自定义的属性就正好相反。


深度扩展:

"脚本之家"的文章中,讲到了在JS中对属性进行点操作和JS方法操作时候所遇到的一些问题,这篇文章的作者不知道是哪位大神,但是可以感受到这位大神处理问题的认真态度,从这篇文章中可以很深入地了解这两个“属性”之间的区别,在这里我简单地把这篇文章做一个记录。

文章开头从语义上,表明attribute是property的子集,(对于这个观点,我并不确定,所以保持怀疑态度,因为我理解的property是固有属性,attribute是自定义属性,它们是不同的集合)而在JavaScript中,property和attribute更是有明显的区别。我们用代码来说明区别在哪:

---attribute

  1. //HTML
  2. <div id="div1">This is a test division.</div>
  3. <div id="div2">This is a test division.</div>

如果对这个元素的自定义属性"myAttr"进行操作:

  1. var elem1=document.getElementById("div1");
  2. elem1.setAttribute("myAttr","testAttr");
  3. alert(elem1.getAttribute("myAttr")); //testAttr
  4. alert(elem1.myAttr); //undefined
  5. var elem2=document.getElementById("div2");
  6. elem2.myAttr = "testAttr";
  7. alert(elem2.getAttribute("myAttr")); //null,没有设置上
  8. alert(elem2.myAttr); //testAttr
  9. //查看DOM可以发现,使用点操作给元素赋的值并没有写进元素的属性中,只是在点操作读取的时候可以都出来

在这里我们可以看出来,似乎setAttribute()getAttribute()成了一对CP,而点操作必须自己跟自己玩儿。用文中的一句话就是:在对自定义属性的处理方式上,DOM属性的标准方法和点号方法不再具有任何关联性。

---property

  1. //HTML
  2. <a id="a1" href="">This is a test element.</a>
  3. <a id="a2" href="">This is a test element.</a>

如果对这两个元素的属性"href"进行操作:

  1. var elem1=document.getElementById("a1");
  2. elem1.setAttribute("href","testProp");
  3. alert(elem1.getAttribute("href")); //testAttr
  4. alert(elem1.href); //path/testProp
  5. var elem2=document.getElementById("a2");
  6. elem2.href = "testProp";
  7. alert(elem2.getAttribute("href")); //testAttr
  8. alert(elem2.href); //path/testProp

两组alert的结果是一样的,两个方法都能够将属性值设置进DOM中,.getAttribute()方法返回的是文件路径字面量(相对路径),而点操作则是返回的计算值,是指定的文件的绝对路径。由此可以猜测的是,对于元素的固有属性property,DOM标准方法和点操作是相通的。

之后,我又对两个<div>的class属性进行了测试,发现结果和进行attribute测试的结果一样,结合脚本之家的这篇文章,可能只有href, src, value这几个属性是固有属性里面DOM方法操作和点操作相通的吧,具体原因现在还不是很懂。

结语:(一)对于jQuery中方法的使用,固有属性就该用.prop(),而自定义属性就该用.attr();(二)而在JS中,虽然property和attribute有一点混乱了,但仍然可以保持property和attribute分别是固有属性和自定义属性的这个观点,这样区别开来不容易造成混淆,同时为了避免bug的出现,还是尽量在使用的时候,.setAttribute().getAttribute()相对应,点操作与点操作对应,不把DOM方法和点操作混着用(即使有时候是相通的),这样可以避免错误的产生。(三)在涉及到href, src, value这三个属性的计算值(绝对路径)的时候,用点操作。

jQuery中.attr()和.prop()的区别的更多相关文章

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

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

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

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

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

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

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

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

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

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

  6. jquery中attr与prop的区别

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

  7. Jquery中attr()与prop()的区别

    在jQuery中,attr()函数和prop()函数都用于设置或获取指定的属性,它们的参数和用法也几乎完全相同.但是,这两个函数的用处却并不相同.下面我们来详细介绍这两个函数之间的区别. 1.操作对象 ...

  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. Spark RDD类源码阅读

    每天进步一点点~开搞~ abstract class RDD[T: ClassTag]( //@transient 注解表示将字段标记为瞬态的 @transient private var _sc: ...

  2. Linux修改/etc/profile不生效的问题

    今天在原来的机器上修改了JDK的路径配置,但死活不生效. 后来查了~/.bash_profile文件,里面没有配置. 最后查~/.bashrc文件,发现里面有JDK的配置

  3. Flex中设置Camera的视频清晰质量的最佳配合

    今天需要设置Flex中的Camera组件的一些属性,后来发现清晰度不是很高,于是捣鼓了上午半天,设置了很多的参数,竟然发现手册上就是有现成的一些设置方法,郁闷!不过我还是专门设置了几个有用和必要的属性 ...

  4. AX dynamics 2012 ssrs 开发报错:Native compiler return value: ‘[BC30179]

    具体报错内容如下: System.Web.Services.Protocols.SoapException: An unexpected error occurred while compiling ...

  5. 关于oracle中to_char和to_date的用法

      一.24小时的形式显示出来要用HH24 select to_char(sysdate,'yyyy-MM-dd HH24:mi:ss') from dual; select to_date('200 ...

  6. JavaScript(Iframe、window.open、window.showModalDialog)父窗口与子窗口之间的操作

    一.Iframe 篇 公共部分 //父对象得到子窗口的值 //ObjectID是窗口标识,ContentID是元素ID function GetValue(ObjectID,ContentID) { ...

  7. 树莓派B+上手小记--使用HDMI线连接显示器

    入手还算比较顺利,一开始使用网上下的别人精简的OS,发现ACT及PWR灯一直亮着,上网查说用HDMI连接显示器需要修改配置文件config.txt,但修改后情况依旧. 如果还是用官方的系统试试吧,上网 ...

  8. NHibernate系列文章十六:使用程序集管理NHibernate项目(附程序下载)

    摘要 在实际的项目中,经常是将NHibernate的实体关系映射类做成独立的工程(assembly dll),只对外提供Session调用的接口.这个程序集作为数据访问层,可以被上面的多个工程(ASP ...

  9. scrollView实现基础中心点缩放及与UIPageControl结合使用

    一般来说scrollView与UIPageControl都是结合使用,因为在使用滚动视图的时候 ,使用UIPageControl,用户可以 清楚 的明白显示的内容有多少页,如果 没有的话,总不能让用户 ...

  10. 如何使用XproerUI库(WTL)-XproerUI界面库教程

    版权所有 2009-2015 荆门泽优软件有限公司 保留所有权利 产品首页:http://www.ncmem.com/apps/xproerui/index.asp 开发文档(SkinStudio): ...