el.value与el.getAttribute("value")的区别

当我们使用querySelector找到一个DOM对象之后,如果需要得这个对象的某个属性值,比如一个input的value值,好像使用el.value和el.getAttribute("vaue")得到的结果都是一样。那么为什么会有这两种看起来差不多的方法?这两种方法有什么区别吗?

其实这两个看起来差不多的方法从定义上就完全不一样。getAttribute返回的是HTML元素的属性,而el.value返回的是定义在DOM对象上的value属性。由于中文都翻译为属性,比较容易混淆,英文的区别比较明显:DOM上定义的是property(DOM是一个对象),而HTML上定义的是attribute。

一般来说property和attribute是一一对应的关系,所以一般情况下el.getAttribute('value')和el.value的结果是一样的。但是要注意下面几个区别:

  • property可以为不同的类型,比如boolean、string等等
  • attribute全部为string
<input type="checkbox" checked=true/>

console.log(typeof checkbox.checked);                    //boolean
console.log(typeof checkbox.getAttribute('checked'));    //string
  • 一般来说,property和attribute的值是相同的,但也有不相同的例子,比如a元素的href属性:
<a href="/" id="hey"></a> 

var a = document.getElementById('hey');    //返回"/"
console.log(a.getAttribute('href'));       //返回当前网页的完整地址
console.log(a.href);
  • 如果对象有默认值,则attribute将始终返回默认值,而property则会实时更新。比如input元素,如果设置了一个默认的value值,则getAttribute将始终返回这个默认值,el.value则会随着用户的输入而更新。

正是因为这些区别,一般建议使用dom对象的property(既使用el.value)而非attribute。只在以下两种情况可使用元素的attribute:

  • 当访问自定义attribute时(无同步的DOM对象)
  • 当你确实需要attribute的值时(比如确定需要input的默认值)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,981评论 18 399
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,643评论 19 139
  • 人生这堂课,就是用生活来实践生活,用生活来解读生活。
    夕阳无限美阅读 1,007评论 0 0
  • 你有你的生活,我有我的日子,似乎是两条平行线。 偶尔会想起,这个地方我们一起来过,这条路我们一起走过,这样食物我们...
    偣洔箬素阅读 890评论 0 0
  • iTunes 12.7.0.166之后去掉了应用商店,但由于企业级用户需要,就额外发布的一个版本为12.6.3.6...
    lvjesus阅读 6,785评论 0 0