1.对象属性浅度克隆
let clone = Object.assign({}, target)
2.对象属性深度克隆
简单的深克隆可以使用JSON.parse()和JSON.stringify(),这两个api是解析json数据的,所以只能解析除symbol外的原始类型及数组和对象
let cloneObj = JSON.parse(JSON.stringify(target))
3.原始类型的深度克隆
检查是否为原始数据
function isPrimitive(value) {
return isStatic(value) || typeof value === 'symbol'
}
检查是否为类数组
function isArrayLike(value) {
return value != null && isLength(value.length) && !isFunction(value);
}
判断是否为对象
function isPlainObject(obj) {
return Object.prototype.toString.call(obj) === '[object Object]'
}
获取数据类型
function getRawType(value) {
return Object.prototype.toString.call(value).slice(8, -1)
// return Object.prototype.toString.apply(value).slice(8, -1)
// return Object.prototype.toString.bind(value).slice(8, -1)()
}
//getoRawType([]) ==> Array
克隆函数
clone = (value,deep) => {
if(isPrimitive(value)){ // 原始数据类型
return value
}
if (isArrayLike(value)) { //是类数组
value = Array.prototype.slice.call(value) // 类数组转数组
return value.map(item => deep ? clone(item, deep) : item)
} else if(isPlainObject(value)){ //是对象
let target = {}, key;
for (key in value) {
value.hasOwnProperty(key) && ( target[key] = deep ? clone(value[key], deep) : value[key] )
}
}
let type = getRawType(value) // 获取数据类型
switch(type){
case 'Date':
case 'RegExp':
case 'Error': value = new window[type](value); break;
}
return value
}