function deepClone(obj){
// 要原路返回 不做深拷贝
if(obj == null) return obj; //如果是null或者undefined我就不进行拷贝操作
if(obj instanceof Date) return new Date(obj);//如果拷贝的是Date日期对象 那么直接返回一个新的日期就好啦
if(obj instanceof RegExp) return new RegExp(obj);
if(typeof obj == 'function') return obj;
//可能是对象 或者 普通的值(原始数据类型) 如果是一个函数的话 是不需要深拷贝的
if(typeof obj !== 'object') return obj;
/*
是对象的话就要进行深拷贝
对象有可能是数组[] 也有可能是对象{}
判断是数组还是对象 Object.prototype.toString.call(obj) == [object Array]?[]:{}
console.log(obj.constructor) 可以利用原型对象身上的constructor去做判断,
可以通过传进来的对象的构造器快速实例化一个对象 传进来的是数组 那么得到的就是空数组传进来的是对象 那么得到的就是空对象
*/
let cloneObj = new obj.constructor;
// 遍历对象的属性 一层一层地遍历赋值才是深拷贝
for(let key in obj){
if(obj.hasOwnProperty(key)){
// cloneObj[key] = obj[key]; //如果obj[key]还是一个对象的话 就是说对象有多层 对象嵌套对象 就得用递归实现了
//实现一个递归拷贝
cloneObj[key] = deepClone(obj[key]);
}
}
return cloneObj
}
简化下↓↓↓↓↓
function deepClone(obj){
if(obj == null) return obj;
if(obj instanceof Date) return new Date(obj);
if(obj instanceof RegExp) return new RegExp(obj);
if(typeof obj == 'function') return obj;
if(typeof obj !== 'object') return obj;
let cloneObj = new obj.constructor;
for(let key in obj){
if(obj.hasOwnProperty(key)){
cloneObj[key] = deepClone(obj[key]);
}
}
return cloneObj
}