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
进行深拷贝以后,两个对象之间就不会再有关联了