vue项目中关于克隆对象

当对象属性与其他元素绑定,且请求时需要特定数据格式时,需要避免直接赋值导致的引用问题。文中提到,直接使用等号赋值会导致浅拷贝,改变其中一个对象的属性会影响到另一个。为了解决这个问题,可以使用lodash库的cloneDeep方法进行深拷贝,确保两个对象互不影响。在Vue.js环境中,这种方法尤其适用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对象中的属性已经与其他的一些图标绑定,但是发送请求的时候。又对这个对象里的某些属性的属性值的数据格式有要求,此时可以对这个对象进行克隆

直接让两个对象相等不可以么???很明显不可以,要不我还记录这玩意儿干啥啊

例如

const test1 = {"a":1,"b":2}

const test2 = test1

test2.b = 100

console.log(test1.b)                        //结果为100

从而我们可以得知,这种直接相当的会触发对象的引用机制,我看也有把这种复制方法称为浅拷贝

那如何解决这个情况呢?

在vue中可以利用lodash,在终端直接下载lodash,然后

import _ from "lodash"

我们使用cloneDeep(object)方法

import _ from "lodash"    //先下载lodash并引入lodash




const test1 = {"a":1,"b":2}
const test2 = _.cloneDeep(test1)

test2.b = 100

console.log(test1.b)      //输出结果为2

进行深拷贝以后,两个对象之间就不会再有关联了

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值