美文网首页
手写一个深拷贝

手写一个深拷贝

作者: 来了啊小老弟 | 来源:发表于2020-10-13 09:39 被阅读0次
 // 深拷贝
  deepClone(obj = {}){
    var cloneObj;
    //当输入数据为简单数据类型时直接复制
    if(typeof obj!=='object'|| obj == null){cloneObj=obj;}
    //当输入数据为对象或数组时
    else if(obj&&typeof obj==='object'){
        //检测输入数据是数组还是对象
        cloneObj=Array.isArray(obj)?[]:{};
        for(let key in obj){
            if(obj.hasOwnProperty(key)){ //保证key不是原型的属性 hasOwnProperty判断是否是属于自己的属性,而不是继承自原型的属性
                if(obj[key]&&typeof obj[key]==='object') {
                    //若当前元素类型为对象时,递归调用
                    cloneObj[key] = deepClone(obj[key]);
                }
                //若当前元素类型为基本数据类型
                else{cloneObj[key]=obj[key];}
            }

        }
    }
    return cloneObj;
  }

相关文章

  • 深入JavaScript Day33 - 序列化实现深拷贝的缺点

    一、序列化实现深拷贝的缺点、手写深拷贝 1、借助序列化实现深拷贝,有哪些缺点? ①不能拷贝函数 ②不能拷贝Symb...

  • 手写深拷贝

    什么是深拷贝? 简单理解:b是a的一份拷贝,b中没有对a中对象的引用。另一种理解:b是a的一份拷贝,把b和a各画出...

  • 手写深拷贝

    注意:Object.assign()不是深拷贝 语法:Object.assign(target, ...sourc...

  • 手写深拷贝

    手写深拷贝 深拷贝 深拷贝简单理解就是b是a的一份拷贝,且b中不存在a中对象的引用 深拷贝的实现 1.JSON序列...

  • 手写深拷贝

    1. 简述深拷贝 JavaScript 中有2种变量类型:值类型(基本类型)和引用类型。深拷贝和浅拷贝都是针对引用...

  • 深拷贝(手写)

  • 手写深拷贝

    深拷贝

  • 手写深拷贝

  • 手写深拷贝

    方案1.序列化反序列化 上面的代码b就是a的深拷贝当我们修改b里面的值的时候,a的值不会跟着变化。 1.1.缺点 ...

  • 手写深拷贝

网友评论

      本文标题:手写一个深拷贝

      本文链接:https://www.haomeiwen.com/subject/vonmpktx.html