js的深拷贝和浅拷贝常用方法

**

一 浅拷贝

**

(1) Object.assign()

var obj1 = {a: 1, b: 2}
 
var obj2 = Object.assign({}, obj1)
 
obj2.a = 4
 
console.log(obj1, obj2)
// {a: 1, b: 2}, 
// {a: 4, b: 2}

(2) 解构赋值

var obj1 = {a: 1, b: 2}
 
var obj2 = {...obj1}
 
obj2.a = 4
 
console.log(obj1, obj2)
// {a: 1, b: 2}, 
// {a: 4, b: 2}

但这两种拷贝有一个问题就是只能赋值一层,假设我们有如下数据结构

var obj1 = [{
    name: 'Bob',
    childs: ['kimi', 'giao']
}]
 
var obj2 = [...obj1]
 
obj2[0].childs = []
 
console.log(obj1, obj2)

在这里插入图片描述
**

二、深拷贝

**

(1) 利用json.stringify

var obj1 = [{
    name: 'Bob',
    childs: ['kimi', 'giao']
}]
 
var obj2 = JSON.parse(JSON.stringify(obj1))
 
obj2[0].childs = []
 
console.log(obj1, obj2)

在这里插入图片描述

var obj1 = [{
    name: 'Bob',
    childs: ['kimi', 'giao'],
    fn: function() {},
    age: undefined
}]
 
var obj2 = JSON.parse(JSON.stringify(obj1))
 
obj2[0].childs = []
 
console.log(obj1, obj2)

在这里插入图片描述
我们从结果中发现,值为undefined,或者function的时候并不会拷贝过来。

(2) 利用递归来实现一个方法进行拷贝

var obj1 = [{
    name: 'Bob',
    childs: ['kimi', 'giao'],
    fn: function() {},
    age: undefined
}]
 
var obj2 = extend(obj1)
 
obj2[0].childs = []
 
console.log(obj1, obj2)
 
function extend(data) {
    if (typeof data === 'object' && data) {
        let val = typeof data.length === 'number' ? [] : {}
        for(let i in data) {
            val[i] = extend(data[i])
        }
        return val
    } else {
        return data
    }
}

在这里插入图片描述

(3)利用loadsh的封装方法_.cloneDeep方法实现(代码略)

*

总结

拷贝的目的就是我在拷贝你之后,我和你长得一样,但是又不会影响你

通俗的讲浅拷贝只能拷贝一层(改变这一层不会相互影响),如果遇到基本数据类型直接拷贝,遇到引用类型数据就拷贝地址,例如对象obj => {a:{c:1}, b:666}实行浅拷贝后得到对象obj1,如果obj1修改b或a属性不会影响obj的b或a属性,但是如果obj1修改a.c属性会改变obj的a.c属性,深拷贝就是全部复制,二者所有层数永远独立不会相互影响

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值