浅克隆和深克隆的用法

浅克隆
定义:拷贝后新对象的属性和原对象中的属性不会关联,但是方法都指向同一个地址

es6剩余参数解构
let b = {...obj}

Object.assign(复制方, 被复制方)  返回枚举后的新对象
let b = Object.assign({}, obj);   

slice()切割
let b = obj.slice();  
深克隆
定义:
	拷贝一个新对象出来,但是新对象的地址和原对象的地址不一样
	任意一方修改数据不会影响另一方,只是刚开始拷贝过去属性和方法长得一样
  
 1、递归  (原生)  面试用的
function Deepclone(obj) {
     // 1、传入的是数组还是对象
      let deepObj = Array.isArray(obj) ? [] : {};
      // 2、判断obj是否为基本数据类型 object
      if (obj && typeof obj === 'object') {
        // 3、for in 遍历对象中的每个属性
        for (key in obj) {
           // 4、判断 obj 中是否有这个key属性
          if (obj.hasOwnProperty(key)) {
            // 5、判断obj中的key是否都为基本数据类型 object
            if (obj[key] && typeof obj[key] === 'object') {
              // 6、是的话递归将每个key插入到 deepObj 中
              deepObj[key] = Deepclone(obj[key])
            } else {
              // 7、不是的话等于他原来的样子
              deepObj[key] = obj[key]
            }
          }
        }
      }
      // 8、最后把结果返回出去
      return deepObj
    }
    
let obj = { n: 1 };   
let b = Deepclone(obj); //  b = { n: 1 }

 2、插件lodash     开发用这个,健壮性强
 下载 npm i lodash
 const _ = require('lodash');
 let b = _.cloneDeep(obj);  // { n: 1 }

 3JSON.parse和JSON.Stringify   随便
 let b = JSON.parse(JSON.Stringify(obj));  // { n: 1 }
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值