美文网首页
深拷贝与浅拷贝

深拷贝与浅拷贝

作者: 陈大事_code | 来源:发表于2019-05-05 15:28 被阅读0次

    本文将讲述一下几点

    1. 深拷贝与浅拷贝的区别。
    2. 深拷贝的常用方法

    切记。只有引用类型才存在深拷贝与浅拷贝的问题哦~,基本类型是不存在这个问题的,都是完全拷贝,直接赋值即可,就是两个完全没关系的值。

    区别

    • 拷贝内容。深拷贝:所有类型数据都会完全拷贝。浅拷贝:基本类型会完全拷贝,但是引用类型(包含:对象、数组)只会拷贝引用(即:内存地址)
    • 内存地址。深拷贝:不同的内存地址。浅拷贝:引用类型数据是同一块地址。

    深拷贝常用方法

    • Json方法(推荐使用,也是最常用的方法,简单快捷)
    // 先将obj对象转为json字符串,然后再将json字符串转为json对象。 
    let objCopy = JSON.parse(JSON.stringify(obj));
    

    说明:其中obj与objCopy没有任何关系哦~。

    • for...in遍历复制
    // vue中环境测试
    deepClone(obj) {
          let result = {}
          //for...in遍历的obj对象的键名,这点要注意与for...of的区别哦~
          for (let key in obj) {
            if (obj[key] && typeof obj[key] === "object") {
              //如果对象的属性值为object的时候,递归调用deepClone,即在吧某个值对象复制一份到新的对象的对应值中。
              result[key] = this.deepClone(obj[key]);
            } else {
              //如果对象的属性值不为object的时候,直接复制参数对象的每一个键值到新的对象对应的键值对中。
              result[key] = obj[key];
            }
          }
          return result;
        }
    

    其中:我这边是默认是传入的对象哦~,如果存在其他类型,需要进行判断。

    相关文章

      网友评论

          本文标题:深拷贝与浅拷贝

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