html5

el.value与el.getAttribute("v

2015-08-25  本文已影响658人  ifcode

当我们使用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的结果是一样的。但是要注意下面几个区别:

<input type="checkbox" checked=true/>

console.log(typeof checkbox.checked);                    //boolean
console.log(typeof checkbox.getAttribute('checked'));    //string
<a href="/" id="hey"></a> 

var a = document.getElementById('hey');    //返回"/"
console.log(a.getAttribute('href'));       //返回当前网页的完整地址
console.log(a.href);

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

上一篇 下一篇

猜你喜欢

热点阅读