javascript深拷贝和浅拷贝以及实现方法(推荐)

纸飞机 发表于 2021/10/19 22:15:46 2021/10/19
【摘要】 深拷贝和浅拷贝的区别? 浅拷贝: 将原对象或原数组的引用直接赋给新对象,新数组,新对象/数组只是原对象的一个引用。 深拷贝: 创建一个新的对象和数组,将原对象的各项属性的“值”(数组的所有元素)拷贝过来,是“值”而不是“引用”。 为什么要用深拷贝? 我们希望在改变新的数组(对象)的时候,不改变原数组(对象) 一般是针对Arra...

深拷贝和浅拷贝的区别?

浅拷贝: 将原对象或原数组的引用直接赋给新对象,新数组,新对象/数组只是原对象的一个引用。

深拷贝: 创建一个新的对象和数组,将原对象的各项属性的“值”(数组的所有元素)拷贝过来,是“值”而不是“引用”。

为什么要用深拷贝?

我们希望在改变新的数组(对象)的时候,不改变原数组(对象)

一般是针对Array和Object类型数据的复制

对象深拷贝方法

1.JSON的方式实现


  
  1. function deepClone(obj) {
  2. let _obj = JSON.stringify(obj);
  3. return JSON.parse(_obj);
  4. }

2.递归的方式实现深拷贝---推荐


  
  1. function deepClone(obj){
  2.   let objClone = Array.isArray(obj) ? [] : {};
  3.   if (obj && typeof obj === 'object') {
  4.     for(let key in obj){
  5.       if (obj[key] && typeof obj[key] === 'object'){
  6.         objClone[key] = deepClone(obj[key]);
  7.       }else{
  8.         objClone[key] = obj[key]
  9.       }
  10.     }
  11.   }
  12.   return objClone;
  13. }

3.通过Object.assign()拷贝---不推荐


  
  1. function deepClone(obj){
  2. if(obj instanceof Object){
  3. return Object.assign({},obj);
  4. }else{
  5. return obj;
  6. }
  7. }

  注意:Object.assign()并非真正意义上的深拷贝,因为如果被拷贝的对象层数超过1层,那么就无    法通过Object.assign()深拷贝,如下图

数组深拷贝方法

1.concat(arr1, arr2,....)


  
  1. function deepClone(arr){
  2. if(arr instanceof Array){
  3. return [].concat(arr);
  4. }else{
  5. return arr;
  6. }
  7. }

2.slice(idx1, idx2)

参数可以省略


  
  1. function deepClone(arr){
  2. if(arr instanceof Array){
  3. return arr.slice();
  4. }else{
  5. return arr;
  6. }
  7. }

3.JSON的方式实现


  
  1. function deepClone(arr) {
  2. let _arr = JSON.stringify(arr),
  3. return JSON.parse(_arr);
  4. }

无论是对象还是数组,想必大家应该大部分用的都是JSON.parse(JSON.stringify(data))吧,虽有弊端,但不影响大部分使用😂。

多维数组深拷贝


  
  1. function deepcopy(arr) {
  2. var out = [],i = 0,len = arr.length;
  3. for (; i < len; i++) {
  4. if (arr[i] instanceof Array){
  5. out[i] = deepcopy(arr[i]);
  6. }
  7. else out[i] = arr[i];
  8. }
  9. return out;
  10. }

文章来源: root181.blog.csdn.net,作者:前端纸飞机,版权归原作者所有,如需转载,请联系作者。

原文链接:root181.blog.csdn.net/article/details/118584594

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件至:cloudbbs@huaweicloud.com进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容。
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。