目录
如何区分深拷贝与浅拷贝
简单点来说,就是假设B复制了A,当修改A时,看B是否会发生变化,如果B也跟着变了,说明这是浅拷贝,拿人手短,如果B没变,那就是深拷贝,自食其力。
第一级属性深拷贝,以后级别属性浅拷贝
let a = {name: {asd: '123'}};
let b = Object.assign({}, a);
a = {w: []};
console.log(a); // w: []
let m = {name: {asd: '123'}};
let n = Object.assign({}, m);
m.name = [];
console.log(n); // name: {asd: "123"}
let x = {name: {asd: '123'}};
let y = Object.assign({}, x);
x.name.asd = 456;
console.log(y); // name: {asd: 456}
let p = {name: {asd: {xyz: '123'}}};
let q = Object.assign({}, p);
p.name.asd.xyz = 456;
console.log(p); // name: asd: {xyz: 456}
怎样才是严谨的深拷贝?
严谨是一个相对概念,深拷贝的写法也有N种,我个人是采用3种办法,一个是JSON.parse(JSON.stringify(obj))
,一个是去github上找一个深拷贝的开源代码,或者是使用lodash的深拷贝就得了。