深浅拷贝
# 浅拷贝
只会对第一层的可枚举的属性进行独立的复制;对于基本数据类型会完全拷贝一份数据,引用数据类型只拷贝了内存地址。一些常用的方法有:
Object.assign
- ES6 扩展运算符。
let zhangSan = {...user}
Array.slice
和Array.concat
# 深拷贝
JSON.parse(JSON.stringify(data))
- 函数、
undefined
、symbol
这几种类型无法被拷贝,经过JSON.stringify
后会消失 - 无法拷贝不可枚举的属性
- 无法拷贝对象的原型链
Date
类型会变成字符串RegExp
类型会变成空对象- 对象中含有
NaN
、Infinity
以及-Infinity
, JSON 序列化的后会变成 null - 无法拷贝对象的循环应用,即对象成环 (
obj[key] = obj
)
- 函数、
# 深度克隆
递归拷贝所有层级
// 判断arr是否为一个数组,返回一个bool值
function isArray (arr) {
return Object.prototype.toString.call(arr) === '[object Array]';
}
// 深度克隆
function deepClone (obj) {
// 对常见的“非”值,直接返回原来值
if([null, undefined, NaN, false].includes(obj)) return obj;
if(typeof obj !== "object" && typeof obj !== 'function') {
//原始类型直接返回
return obj;
}
var o = isArray(obj) ? [] : {};
for(let i in obj) {
if(obj.hasOwnProperty(i)){
o[i] = typeof obj[i] === "object" ? deepClone(obj[i]) : obj[i];
}
}
return o;
}
export default deepClone;
上次更新: 2022/08/23, 18:58:25