谈谈深浅复制

深浅拷贝 也叫 深浅复制,
与 引用数据类型 的复制相关的,
对象和数组的复制

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

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

浅拷贝

let arr1 = [1,2,3,4,5];
let arr2 = arr1;
arr2[0] = '北京';
// arr2 和 arr1 中存储的是相同的内存地址 ,指向的是一个相同的数组
// 如果 arr1 或者 arr2 对 这个数组做出修改,都会影响另一个变量的输出
console.log(arr1);
console.log(arr2);

代码执行结果如下
在这里插入图片描述

深拷贝

 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中用递归函数来实现解决
 在jQuery中,提供了,专门的方法来实现 深浅拷贝/深浅复制
  $.extend()方法
  语法形式1: $.extend( 是否深拷贝(不写) ,  对象1,对象2,对象3...) 
  执行的是浅拷贝
  语法形式2: $.extend( 是否深拷贝(true) ,  对象1,对象2,对象3...) 
  执行的是深拷贝

使用 extend()方法来 完成 拷贝 
对于复制内容来说 ,如果是字符串等 基本数据类型,不会被影响,被修改
对于复制内容 来说 ,如果是应用数据类型中的数据,要考虑是否要执行深浅拷贝
 键名相同的 复制拷贝 , 后面的数据会覆盖之前的数据,是重复赋值的效果
		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);

执行结果如下
在这里插入图片描述

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值