DOM节点Attribute和property有何区别

DOM节点Attribute和property有何区别

property是DOM中的属性,是JavaScript里的对象;
attribute是HTML标签上的特性

dom中的属性默认存在,比如

<input type="text" id="test1" attr='1'/>

打印后value的值为NULL;

基于JavaScript分析property 和 attribute


```html
<input type="text" id="test1" attr='1' value="1" />

打印后得到

attributes: NamedNodeMap
value: "1"
id: "test1"

在attributes同级别的key都是property。
运行以下逻辑代码:

var in1 = document.getElementById('test1');
    in1.value = 'new value of prop';
    console.log(in1.value);				// 'new value of prop'
    console.log(in1.attributes.value);	// 'value="1"'

可见改变property后attributes的值不会得到同步更新。
再运行以下代码:

in1.attributes.value.value = 'new value of attr';
console.log(in1.value);				// 'new value of attr'
console.log(in1.attributes.value);	// 'new value of attr'

可见改变attributes里的property值后property会跟着变化。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值