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

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

修改后

相关推荐
鹏多多1 分钟前
js使用History.replaceState实现不刷新修改浏览器url
前端·javascript·浏览器
AliciaIr1 分钟前
深入理解CSS居中:面试必备的布局技巧与底层原理(下)
前端·css
晴空雨1 分钟前
关于箭头函数和 ES6 的继承与 ES5 组合寄生式继承的区别
javascript
今禾3 分钟前
JavaScript 响应式系统深度解析:从 `Object.defineProperty` 到 `Proxy` 的演进与优化
前端·javascript·面试
闲云野鹤_5 分钟前
HTML+CSS+CSS3学习笔记
前端
zzwar20095 分钟前
实现 Symbol.iterator 方法 让一个普通对象变成 可迭代对象(iterable)
前端
鹏程十八少6 分钟前
1. Android FrameWork之系统启动的流程:Zygote、SystemServer 与 Binder 的三角博弈
前端
看晴天了6 分钟前
React学习(二),2025/5/10,笔记记录
前端
Mintopia7 分钟前
《会聊天的文件筐:用 Next.js 打造“图音双绝”的上传组件》
前端·javascript·aigc
我想说一句18 分钟前
响应式原理揭秘
前端·前端框架