Javascript中attribute与property的区别

attribute是一个类(伪)数组,每个 DOM元素都有一个attribute用来存放它所有的特性(包括系统定义的特性,如:class、id和自定义的特性),每个特性以名值对(name=“value”)的形式存放在attribute类数组中,比如下面的节点:

<div class="wrapper" id="wrepper" uname="yuan">hello</div>
 <script type="text/javascript">
    var elem=document.getElementById("wrepper")
    console.log(elem.attributes)
 </script>

输出:

> NamedNodeMap(3) [ class="wrapper", id="wrepper", nname="yuan" ]

可以通过各个节点的索引号访问节点的属性和值:

console.log(elem.attributes[0])//class="wrapper"
console.log(elem.attributes[0].name)//class
console.log(elem.attributes[0].value)//wrapper

但是IE6-7将很多东西都放在attribute中,上面的访问方法和标准浏览器的返回结果又不同。通常要获取一个attribute节点的属性值直接用elem.getAttribute(“name”)的方法:

console.log(elem.getAttribute("class"));//wrapper

要设置一个attribute节点的属性值用elem.setAttribute(“name”,“value”)的方法,删除用elem.removeAttribute(“name”)。
如果把DOM元素看成一个对象,那么property就是存放在对象中的多个名值对(name=“value”);
每个DOM元素中自定义的属性,基本上都有一个property属性,这些属性可以通过attribute或property添加、删除、修改;
但是对于用户用attribute和property自定义的属性,只可以通过调用attribute/property来进行修改;attribute定义的自定义属性在HTML标签中可见。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值