其他分享
首页 > 其他分享> > js的深拷贝的理解和实现

js的深拷贝的理解和实现

作者:互联网

一:什么是深拷贝?

举例:a=b,当改变a时b也改变这样的copy就是浅拷贝,反之当改变a时b不会改变就是深拷贝

二:实现深拷贝

1、最简单方法就是使用JSON.stringfy()和JSON.parse()。

var syb = Symbol('obj');
var person = {
   name :'tino',
   say: function(){
      console.log('hi');
   },
   ok: syb,
   un: undefined
}
var copyPerson = JSON.parse(JSON.stringify(person))

但是有局限性:当值为undefinedfunctionsymbol 会在转换过程中被忽略,对象值有这三种的话用这种方法会导致属性丢失。

2、通用方法(递归复制)

deepClone => (obj){
    let objClone = Array.isArray(obj)?[]:{};
    if(obj && typeof obj==="object"){
        for(key in obj){
            if(obj.hasOwnProperty(key)){
                //判断ojb子元素是否为对象,如果是,递归复制
                if(obj[key]&&typeof obj[key] ==="object"){
                    objClone[key] = deepClone(obj[key]);
                }else{
                    //如果不是,简单复制
                    objClone[key] = obj[key];
                }
            }
        }
    }
    return objClone;
}

  

  

标签:obj,objClone,js,JSON,理解,key,var,拷贝
来源: https://www.cnblogs.com/piaobodewu/p/10393863.html