DOM映射机制

1.形参跟arguments

arguments是所有实参的集合(类数组对象),与形参无关
arguments与形参有映射机制

//当形参与实参长度一致时,arguments与形参有映射机制
function test(a, b, c) {
console.log(arguments)  //Arguments(3) [1, 2, 3, callee: ƒ, Symbol(Symbol.iterator): ƒ]
  arguments[0] = 100
console.log(arguments)  //Arguments(3) [100, 2, 3, callee: ƒ, Symbol(Symbol.iterator): ƒ]
console.log(a, b, c)  //100, 2, 3
}
test(1, 2, 3)
//当实参数量比形参数量少时,多余的形参与arguments不存在映射关系。即使改变形参的值,对应的arguments[i]仍然是undefined。

2.DOM的映射机制:

页面中的html元素和js中通过相关方法获取到的元素或者元素对象存在映射关系(一个修改另一个也跟着修改)
xxx.style.color = 'red' //就是使用映射机制
使用document.getElementById()等方法获取元素也有映射机制的存在

<ul>
	<li>迪迦</li>
	<li>佐菲</li>
	<li>赛文</li>
	<li>泰罗</li>
	<li>杰克</li>
	<li>艾斯</li>
	<li>初代奥特曼</li>
</ul>
let ul = document.querySelector("ul")
let li = document.querySelectorAll("li")
let node = document.createElement("li")
node.appendChild(document.createTextNode('欧布'))
ul.appendChild(node)
console.log(li.length);  //7

上面代码可以看出通过querySelectorAll拿到的li元素长度并没有发生改变,还是之前长度,并且当修改li样式时,新增的元素也不会改变

<ul>
	<li>迪迦</li>
	<li>佐菲</li>
	<li>赛文</li>
	<li>泰罗</li>
	<li>杰克</li>
	<li>艾斯</li>
	<li>初代奥特曼</li>
</ul>
let ul = document.querySelector("ul")
let li = document.getElementsByTagName("li")
let node = document.createElement("li")
node.appendChild(document.createTextNode('欧布'))
ul.appendChild(node)
console.log(li.length);  //8

使用getElementsByTagName类似的方法不会有这种映射切断的风险存在。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值