深拷贝(对象和数组的深拷贝)

一、理解

数组的深拷贝:

arr.concat()拷贝的数组 一维数组相当于做深拷贝,多维数组相当于做浅拷贝 。 arr.slice()选取数组的一部分,并返回一个新数组,不修改原数组。

对象的深拷贝:

Object.assign(参数) 简单的对象深拷贝,复杂的还是浅拷贝

二、运用

(1)数据简单

javascript 复制代码
<script>
// ------数组
        var arr = [10, 20, 30];
        var arr1 = arr.concat();
        arr1[0] = 100
        console.log(arr, arr1);//(3) [10, 20, 30]   (3) [100, 20, 30]

        var arr2=arr.slice(0,arr.length);
        console.log(arr,arr2);//(3) [10, 20, 30]  (3) [10, 20, 30]
        arr2[2]=100;
        console.log(arr,arr2);//(3) [10, 20, 30]  (3) [10, 20, 100]

//  -----对象
        var obj = { name: '小明' };
        var obj1 = obj;
        obj1.name = '小红'
        console.log(obj1, obj);//{name: '小红'} {name: '小红'}

        var obj2 = Object.assign({}, obj);
        console.log(obj, obj2);//{name: '小红'} {name: '小红'}
        obj2.name = '小绿'
        console.log(obj, obj2);//{name: '小红'} {name: '小绿'}
</script>

(2)数据复杂

javascript 复制代码
<script>
        var data = {
            code: 1,
            list: [{
                name: "詹桑",
                title: "值",
                arr: [2, 3, 4],
                isShow: true,
                obj: {
                    name: "123"
                }
            }]
        }
</script>

解决方法 三种

1.方法一: JSON.stringify() JSON.parse()

javascript 复制代码
    <script> 
      var data1 = JSON.parse(JSON.stringify(data));
      data1.list[0].name = '大权'
      console.log(data, data1);
    </script>

运行结果:

2.方法二: lodash官网 封装好的深拷贝 _.cloneDeep(value)

javascript 复制代码
<script>
    var data2 = _.cloneDeep(data);
    data2.list[0].name='大权';
    console.log(data, data2);
</script>

运行结果:

3.方法三:递归函数 封装 原生的方法

javascript 复制代码
<script>
        function deepCopy(obj) {
            //1.不是对象,基本数据类型 输出
            if (typeof obj != 'object') return obj
            //2.是对象  ,遍历对象,再拷贝一遍
            var newobj = obj instanceof Array ? [] : {}
            for (var k in obj) {
                newobj[k] = deepCopy(obj[k])
            }
            return newobj
        }
        var newobj = deepCopy(data);
</script>

运行结果:

相关推荐
王老师青少年编程3 小时前
gesp(C++五级)(14)洛谷:B4071:[GESP202412 五级] 武器强化
开发语言·c++·算法·gesp·csp·信奥赛
DogDaoDao3 小时前
leetcode 面试经典 150 题:有效的括号
c++·算法·leetcode·面试··stack·有效的括号
Coovally AI模型快速验证4 小时前
MMYOLO:打破单一模式限制,多模态目标检测的革命性突破!
人工智能·算法·yolo·目标检测·机器学习·计算机视觉·目标跟踪
可为测控4 小时前
图像处理基础(4):高斯滤波器详解
人工智能·算法·计算机视觉
Milk夜雨5 小时前
头歌实训作业 算法设计与分析-贪心算法(第3关:活动安排问题)
算法·贪心算法
BoBoo文睡不醒5 小时前
动态规划(DP)(细致讲解+例题分析)
算法·动态规划
apz_end6 小时前
埃氏算法C++实现: 快速输出质数( 素数 )
开发语言·c++·算法·埃氏算法
仟濹6 小时前
【贪心算法】洛谷P1106 - 删数问题
c语言·c++·算法·贪心算法
CM莫问7 小时前
python实战(十五)——中文手写体数字图像CNN分类
人工智能·python·深度学习·算法·cnn·图像分类·手写体识别
sz66cm7 小时前
LeetCode刷题 -- 45.跳跃游戏 II
算法·leetcode