手写深拷贝的递归实现

85 阅读1分钟

嘿嘿,这个东西一拖再拖拖到了现在,通过chatGPT学到了好多东西,确实很方便开发。 有两个版本,一个简单的深拷贝,一个复杂的

简单的

function deepCopy(obj){
    if(typeof obj != 'object' || obj === null) return obj
    
    let copy = Array.isArray(obj) ? [] : {}
    
    for(let key in obj){
// obj.hasOwnProperty(key)返回一个布尔值,指示对象自身属性中是否具有指定的属性,不算原型链上的
        if(obj.hasOwnProperty(key)){
            obj[key] = deepCopy(obj[key])
        }
    }
    
    return copy
}

复杂的

function deepClone(obj, hash = new WeakMap()) {
  if (obj === null) return obj; // 如果是null或者undefined我就不进行拷贝操作
  if (obj instanceof Date) return new Date(obj);
  if (obj instanceof RegExp) return new RegExp(obj);
  // 可能是对象或者普通的值  如果是函数的话是不需要深拷贝
  if (typeof obj !== "object") return obj;
  // 是对象的话就要进行深拷贝
  if (hash.get(obj)) return hash.get(obj);
  let cloneObj = new obj.constructor();
  // 找到的是所属类原型上的constructor,而原型上的 constructor指向的是当前类本身
  hash.set(obj, cloneObj);
  for (let key in obj) {
    if (obj.hasOwnProperty(key)) {
      // 实现一个递归拷贝
      cloneObj[key] = deepClone(obj[key], hash);
    }
  }
  return cloneObj;
}