vue项目使用深拷贝

vue

浅拷贝 : 只是将数据中所有的数据引用下来,依旧指向同一个存放地址,拷贝之后的数据修改之后,也会影响到原数据的中的对象数据。例如:Object.assign(),...扩展运算符

深拷贝: 将数据中所有的数据拷贝下来,对拷贝之后的数据进行修改不会影响到原数据。

JSON.parse(JSON.stringify(obj))深拷贝的问题

1、如果obj里面存在时间对象,JSON.parse(JSON.stringify(obj))之后,时间对象变成了字符串。

2、如果obj里有RegExp、Error对象,则序列化的结果将只得到空对象。

3、如果obj里有函数,undefined,则序列化的结果会把函数, undefined丢失。

4、如果obj里有NaN、Infinity和-Infinity,则序列化的结果会变成null。

5、JSON.stringify()只能序列化对象的可枚举的自有属性。如果obj中的对象是有构造函数生成的, 则使用JSON.parse(JSON.stringify(obj))深拷贝后,会丢弃对象的constructor。

6、如果对象中存在循环引用的情况也无法正确实现深拷贝。

适用于vue深拷贝

function coppyArray(arr){

return arr.map((e)=>{

if(typeof e==='object'){

return Object.assign({},e);

}else{

return e;

}

})

}  //这个好像不兼容IE所以使用下面那个

function copyArray(arr){

return JSON.parse(JSON.stringify(arr));

}

递归实现深拷贝

function copy (obj) {

let newObj = null

if (typeof obj === 'object' && obj !== null) {

newObj = obj instanceof Array ? [] : {}

for (let i in obj) {

newObj[i] = typeof obj[i] === 'object' ? copy(obj[i]) : obj[i]

}

} else {

newObj = obj

}

return newObj

}

以上是 vue项目使用深拷贝 的全部内容, 来源链接: utcz.com/z/380370.html

回到顶部