vue项目中关于克隆对象

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

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

例如

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

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