如上,当对b 进行两次删除修改时,最终导致a 的值发生了变化
var a = [[1], [2], [3]];
var b = [...a];
b.shift().shift();
console.log(a);
console.log(b);
如上,当对b 进行两次删除修改时,最终导致a 的值发生了变化
var a = [[1], [2], [3]];
var b = [...a];
b.shift().shift();
console.log(a);
console.log(b);
相当于遍历一层, 浅拷贝.
let a = [{}, {}, {}]
let b = []
for (const item of a) {
b.push(item)
}
b[0]['test'] = 1
console.log(a)
console.log(b)
//[ { test: 1 }, {}, {} ]
//[ { test: 1 }, {}, {} ]
如果数组内的值, 是值类型, 那么遍历一层, 就相当于拷贝了它的值, 如果是引用类型, 比如二维数组, 那么就是拷贝了它的引用
10 回答11.4k 阅读
5 回答4.9k 阅读✓ 已解决
4 回答3.2k 阅读✓ 已解决
2 回答2.9k 阅读✓ 已解决
3 回答2.5k 阅读✓ 已解决
3 回答2.3k 阅读✓ 已解决
2 回答2.7k 阅读✓ 已解决
用扩展运算符对数组或者对象进行拷贝时,只能扩展和深拷贝第一层的值,对于第二层极其以后的值,扩展运算符将不能对其进行打散扩展,也不能对其进行深拷贝,即拷贝后和拷贝前第二层中的对象或者数组仍然引用的是同一个地址,其中一方改变,另一方也跟着改变。