vue3引用类型和基础类型深度克隆

深度克隆失效的一个例子

import {
    cloneDeep } from "lodash";
import {
    ref } from "vue";

const navArr = ref([
    "recommend",
    "hot",
    "new",
])
const list1: any = ref([])
const list2: any = ref([])
const list3: any = ref([])

for (let index = 0; index < navArr.value.length; index++) {
   
    const ele = navArr.value[index];
    list1.value[ele] = {
   
        list: [],
        currentIndex: 0,
        pageObj: {
   
            navActive: ele,
            page: 1,
            size: 4,
        }
    }
}

console.log("list1", list1.value);

list2.value = cloneDeep(list1.value)

console.log("list2", list2.value);

list3.value = JSON.parse(JSON.stringify(list1.value))

console.log("list3", list3.value);

在这里插入图片描述

原因是list1和list2初始值用中括号[],但是navArr遍历的时候是对象的方式赋值,
虽然不影响list1赋值,但是类型错了,导致深度克隆会失败,
改成 花括号 对象方式初始值

修改后

在这里插入图片描述

相关推荐

  1. c#基础-引用类型类型的区别

    2024-01-11 15:58:03       19 阅读
  2. 基础数据类型引用数据类型(指针)的区别

    2024-01-11 15:58:03       14 阅读
  3. 深入理解 Golang 中的值类型引用类型

    2024-01-11 15:58:03       41 阅读
  4. 变量的数据类型基本数据类型引用数据类型

    2024-01-11 15:58:03       22 阅读
  5. C# 值类型引用类型

    2024-01-11 15:58:03       13 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-11 15:58:03       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-11 15:58:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-11 15:58:03       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-11 15:58:03       20 阅读

热门阅读

  1. GBASE南大通用ExecuteReader 方法

    2024-01-11 15:58:03       35 阅读
  2. Redis

    2024-01-11 15:58:03       34 阅读
  3. Node.js 多线程实战:如何有效利用多线程能力

    2024-01-11 15:58:03       33 阅读
  4. Linux 内核线程

    2024-01-11 15:58:03       43 阅读
  5. FlinkOnYarn 监控 flink任务

    2024-01-11 15:58:03       38 阅读
  6. Docker 网络

    2024-01-11 15:58:03       30 阅读
  7. html面试题

    2024-01-11 15:58:03       27 阅读
  8. Android亮度调节的几种实现方法

    2024-01-11 15:58:03       40 阅读