递归深拷贝

手写递归方法

  • 递归方法实现深度克隆原理:遍历对象、数组直到里边都是基本数据类型,然后再去复制,就是深度拷贝
  • 特点: 可以实现多层数据结构的深拷贝
  • 在平时操作时,会经常用到深拷贝的方式,为了下次使用节约时间,我直接将深拷贝封装成函数形式方便以后使用.
function deepCopy(data){
  var _data; // 初始化结果,因为结果可能为js任意类型,所以没有赋值.
  // 1. 先验证data是什么类型的数据
 // 如果是基本数据类型,那么直接赋值_data
  if(!(data instanceof Object)){  // 如果是基本数据类型
  _data = data    // 直接赋值
  return _data    /// 输出赋值结果,结束下面语句
}
  if(Array.isArray(data)){  // 验证是不是数组 如果是数组 则进行if语句里面赋值空数组,不是的话直接进行下次判断.
  _data = []   // 对_data赋值空数组
}
  // 验证data是否为对象,如果是对象 则进行if语句里面赋值空对象,不是的话直接进行下次判断.
  if(data.constructor === Object){
  _data = {}  // 对_data赋值为空对象
}
  // 2. 将data中内容添加到 _data中
  for(var i in data){
  // 如果 data[i] 是数组或者对象,则需要进一步深拷贝,所以再次执行deepCopy
  // 将deepCopy() 的返回值 赋值给_data
  _data[i] = deepCopy(data[i])
  }
  return _data
}
posted @   菜鸟解析  阅读(290)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示