JavaScript中的深浅拷贝

深浅拷贝 也叫 深浅复制

     与 引用数据类型 的复制相关的
     对象和数组的复制

     浅拷贝 
     通常意义上,对 数组和 对象的 复制
     浅拷贝的特点:只是简单的复制拷贝 引用数据类型的地址
              地址相同的变量,操作引用数据类型,彼此都会有影响

     深拷贝
     完整的复制拷贝 一个引用数据类型中的数值数据,到另一个引用数据类型中
     两个变量 是两个的独立的引用数据类型 是两个独立的存储空间
     一个变量操作 引用数据类型 不会影响另一个变量


    let arr1 = [1,2,3,4,5];

    这样的语法就是浅拷贝
    执行原理:
    此时是 赋值 arr1 中 存储的 数组的 内存地址
    arr2 和 arr1 中存储的是相同的内存地址 ,指向的是一个相同的数组
    如果 arr1 或者 arr2 对 这个数组做出修改,都会影响另一个变量的输出

    let arr2 = arr1;

    通过arr2,来修改数组,执行之后
    arr2[0] = '北京';

   console.log(arr1);
   console.log(arr2);


     深拷贝
     通过循环遍历,获取 arr3中的所有数值,复制拷贝在arr4中
     此时 arr4 与 arr3 虽然数值相同,但是是两个独立的引用数据类型,是两个独立的空间
     此时 arr4或者arr3,修改数据,不会对另一个引用数据类型造成影响

    let arr3 = [1,2,3,4,5];

    let arr4 = [];

    arr3.forEach(function(item){
        arr4.push(item);
    })

    arr4[0] = '北京';

    console.log(arr3);
    console.log(arr4);

    关键问题是 多维数组,或者是对象中存储对象数组等
    也就是引用数据类型中,再次存储引用数据类型

    数组中嵌套数组,不能只是单间的复制拷贝数组的地址,必须再次解析数组中的具体数值
    还必须再按照原有的嵌套方式,将结构 拷贝至 新的引用数据类型
    原生JavaScript中用递归函数来实现解决
    let arr5 = [ 1,2,3,[4,5,6,[7,8,9,[10,11,12]]]]

     在jQuery中,提供了,专门的方法来实现 深浅拷贝/深浅复制

     $.extend()方法

     将对象2,对象3,等之后的引用数据类型,拷贝复制到 对象1中
    
     语法形式1: $.extend( 是否深拷贝(不写) ,  对象1,对象2,对象3...) 
             执行的是浅拷贝
     语法形式2: $.extend( 是否深拷贝(true) ,  对象1,对象2,对象3...) 
             执行的是深拷贝

    使用 extend()方法来 完成 拷贝 
    对于 复制内容 来说 ,如果是字符串等 基本数据类型,不会被影响,被修改

   对于 复制内容 来说 ,如果是应用数据类型中的数据,要考虑是否要执行深浅拷贝

   键名相同的 复制拷贝 , 后面的数据会覆盖之前的数据,是重复赋值的效果

    小demo:

    var obj1 = { name1:'张三1',age1:18 , sex:'男'};
    var obj2 = { name2:'张三2',age2:19 , sex:'女',data:{time:123} };

    没有写第一个参数true,是浅拷贝
    $.extend(obj1,obj2);

    有第一个参数true,是深拷贝
    $.extend(true ,obj1,obj2 );

     基本数据类型中的数值,不会影响
    obj2.name2 = '李四';
    
    引用数据类型中的数值,会影响
    此时执行的是浅拷贝

    如果是深拷贝,不会印象obj1中的数据
    obj2.data.time = 456;

    console.log(obj1);
    console.log(obj2);
  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值