【进阶篇】javascript对象和数组的深拷贝和浅拷贝

简介: 【进阶篇】javascript对象和数组的深拷贝和浅拷贝

不管是在面试中还是我们的项目中经常会用到数组或者对象的深拷贝,下面我就自己总结的分享给大家。

首先要知道什么是深拷贝?什么是浅拷贝?

      深拷贝:源对象与拷贝对象互相独立,其中任何一个对象的改动都不会对另外一个对象造成影响。

      浅拷贝:拷贝出来的目标对象的指针和源对象的指针指向的内存空间是同一块空间。

1、对象(object)的深拷贝和浅拷贝:

  1.1对象的浅拷贝:

1 var a={x:0,y:0};
2 var b=a;
3       a.x=2;
4 console.log(a); //=>Object {x: 2, y: 0}
5 console.log(b); //=>Object {x: 2, y: 0}

image.gif

1.2对象的深拷贝的几种方法:

 方法1:利用JSON.parse();

var obj1={x:0,y:0};
var obj2=JSON.parse(JSON.stringify(obj1));
    obj1.x=2;
  console.log(obj1);  //=>Object {x: 2, y: 0}
  console.log(obj2);  //=>Object {x: 0, y: 0}

image.gif

方法2:es6中的Object.assign();

var obj1={x:1,y:1};
var obj2=Object.assign({},obj1);
    obj1.x=2;
console.log(obj1);//=>Object {x: 2, y: 1}
console.log(obj2);//=>Object {x: 1, y: 1}

image.gif

 2、数组(Array)的深拷贝和浅拷贝:

 2.1数组的浅拷贝:

var arr1=[1,2,3];
var arr2=arr1;
    arr1.push(5);
  console.log(arr1);//=>[1, 2, 3, 5]
  console.log(arr2);//=>[1, 2, 3, 5]

image.gif

  2.2数组深拷贝的几种方法:

方法一:利用slice()方法:

var arr=[1,2,3];
     var arr2=arr.slice();
         arr.push(4);
      console.log(arr); //=>[1, 2, 3, 4]
      console.log(arr2);//=>[1, 2, 3]

image.gif

   方法二:利用 Object.assign() 方法:  

var arr=[1,2,3];
var arr2=Object.assign([],arr);
    arr.push(4);
   console.log(arr);//=>[1, 2, 3, 4]
   console.log(arr2);//=>[1, 2, 3]

image.gif

方法三:数组的 concat() 方法:  

var arr=[1,2,3];
var arr2=arr.concat();
    arr.push(4);
   console.log(arr);//=>[1, 2, 3, 4]
   console.log(arr2);//=>[1, 2, 3]

image.gif

       方法四:es6中的扩展运算符:  

let arr=[1,2,3];
let [...arr2]=arr;
    arr.push(4);
   console.log(arr);//=>[1, 2, 3, 4]
   console.log(arr2);//=>[1, 2, 3]

image.gif

方法五:通过遍历将值赋值

let arr=[1,2,3];
 let arr2=arr.map((item,index)=>{
           return item;
      })
     arr.push(4);
    console.log(arr);//=>[1, 2, 3, 4]
    console.log(arr2);//=>[1, 2, 3]

image.gif

通过以上5中方法实现了数组的深拷贝,数组arr1和数组arr2相互独自,互不影响。

目录
相关文章
|
6天前
|
JavaScript 前端开发
如何在 JavaScript 中使用 __proto__ 实现对象的继承?
使用`__proto__`实现对象继承时需要注意原型链的完整性和属性方法的正确继承,避免出现意外的行为和错误。同时,在现代JavaScript中,也可以使用`class`和`extends`关键字来实现更简洁和直观的继承语法,但理解基于`__proto__`的继承方式对于深入理解JavaScript的面向对象编程和原型链机制仍然具有重要意义。
|
10天前
|
Web App开发 JavaScript 前端开发
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
|
10天前
|
JavaScript 前端开发 图形学
JavaScript 中 Math 对象常用方法
【10月更文挑战第29天】JavaScript中的Math对象提供了丰富多样的数学方法,涵盖了基本数学运算、幂运算、开方、随机数生成、极值获取以及三角函数等多个方面,为各种数学相关的计算和处理提供了强大的支持,是JavaScript编程中不可或缺的一部分。
|
29天前
|
自然语言处理 前端开发 JavaScript
🛠️ JavaScript数组操作指南:20个精通必备技巧🚀
本文详细介绍了 JavaScript 中的 20 个高效数组操作技巧,涵盖了从基本的添加、移除元素,到数组转换和去重等高级操作。强调了不可变性的重要性,提供了清晰的代码示例,帮助开发者编写更整洁和高效的代码。无论是新手还是经验丰富的开发者,这些技巧都将显著提升您的编码能力,使您在项目中更具竞争力。
21 2
|
1月前
|
JavaScript 前端开发 测试技术
JS都有哪些操作数组的方法
JS都有哪些操作数组的方法
20 3
|
1月前
|
缓存 JavaScript 前端开发
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
31 1
|
28天前
|
JavaScript 前端开发 大数据
在JavaScript中,Object.assign()方法或展开语法(...)来合并对象,Object.freeze()方法来冻结对象,防止对象被修改
在JavaScript中,Object.assign()方法或展开语法(...)来合并对象,Object.freeze()方法来冻结对象,防止对象被修改
15 0
|
1月前
|
JavaScript 前端开发 API
JS中数组的方法flat()怎么用
JS中数组的方法flat()怎么用
13 0
|
1月前
|
JavaScript 前端开发 索引
JavaScript中数组、对象等循环遍历的常用方法介绍(一)
JavaScript中数组、对象等循环遍历的常用方法介绍(一)
20 0
|
4月前
|
存储 JavaScript 前端开发