JavaScript深浅拷贝

理解:浅拷贝,只克隆第一层,修改拷贝后的第二层将影响被拷贝的数据

浅拷贝

三种方式

let  obj={
    a:10,
    b:[10,20],
    c:{
        x:10
    },
    d:/^d+$/
}
let obj1={...obj}  //第一种
let obj2=Object.assign({},obj)  //第二种
//封装 第三种
let obj3={}
    for(let key in obj){
        if(!obj.hasOwnProperty((key))) break;
            obj3[key]=obj[key]
}

深拷贝 

第一种 弊端 对应Key 是函数 日期 正则 会有丢失的情况

let  obj={
    a:10,
    b:[10,20],
    c:{
        x:10
    },
    d:/^d+$/
}
let obj1=let obj4=JSON.parse(JSON.stringify(obj)){...obj}  //第一种  弊端 对应Key 是函数 日期 正则 会有丢失的情况

 

第二种封装
//第二种封装
    function deep(obj){
        if(obj===null) return null
        if(typeof obj!=='object') return obj; //如果不是object直接返回
        if(obj instanceof RegExp){
            return new RegExp(obj) //如果是正则
        }
        if(obj instanceof Date){
            return new Date(obj) //如果是日期
        }
        if(obj instanceof Function){
            return new Function(obj) //如果是函数
        }
//      let newObj={}
//      let newObj=new Object
        let newObj=new obj.constructor  //既能克隆object 也能克隆实例
            for(let key in obj){
                if(obj.hasOwnProperty(key)){
                    newObj[key]=deep(obj[key])
                }
            }
            return newObj
        }
    let obj5=deep(obj)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值