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

深度克隆失效的一个例子

javascript 复制代码
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赋值,但是类型错了,导致深度克隆会失败,

改成 花括号 对象方式初始值

修改后

相关推荐
用户17592342150285 分钟前
D3.js - 基本用法
前端·d3.js
Mr.Liu621 分钟前
小程序30-wxml语法-声明和绑定数据
前端·微信小程序·小程序
76756047922 分钟前
useDateFormat源码解析
前端·源码
Mintopia22 分钟前
Three.js粒子系统开发实战:从基础到性能优化
前端·javascript·three.js
Promise52022 分钟前
大屏"跑马灯" 长列表性能优化
前端·javascript
子玖23 分钟前
初始化项目前的准备
前端·javascript·vue.js
Mintopia23 分钟前
Three.js进阶实战:打造动态光影交互场景 ——结合环境光、聚光灯与相机控制的沉浸式体验
前端·javascript·three.js
贵州数擎科技有限公司24 分钟前
Threejs绘制小兩伞快拿去送给你的女神
前端
Carlos_sam25 分钟前
OpenLayers:封装Overlay的方法
前端·javascript
MariaH25 分钟前
Sequelize模型初探
前端·后端