阅读 526

Object.assign 以及浅、深拷贝

浅(引用)拷贝:共用同一内存地址,你改值我也变

深(引用)拷贝:深拷贝即创建新的内存地址保存值(互不影响)

先说结论:对于Object.assign()而言, 如果对象的属性值为简单类型(string, number),通过Object.assign({},srcObj);得到的新对象为‘深拷贝’;如果属性值为对象或其它引用类型,那对于这个对象而言其实是浅拷贝的。这是Object.assign()特别值得注意的地方。

// 深拷贝
let srcObj = {
  'name': 'lilei',
  'age': '20'
};
 
let copyObj2 = Object.assign({}, srcObj, {
  'age': '21'
});
 
copyObj2.age = '23';
 
console.log('srcObj', srcObj); //{ name: 'lilei', age: '20' }
 
 
 
// 浅拷贝
srcObj = {
  'name': '明',
  grade: {
    'chi': '50',
    'eng': '50'
  }
};
copyObj2 = Object.assign({}, srcObj);
copyObj2.name = '红';
copyObj2.grade.chi = '60';
console.log('新 objec srcObj', srcObj); 
// { name: '明', grade: { chi: '60', eng: '50' } }
复制代码
文章分类
前端
文章标签