品易云推流 关闭
文章详情页
文章 > JavaScript > js递归实现深拷贝

js递归实现深拷贝

js递归实现深拷贝

头像

宋雪维

2021-01-11 15:08:513540浏览 · 0收藏 · 0评论

经过小编之前关于JavaScript深拷贝实现方式的介绍,大家已经知道深拷贝能够实现真正意义上的数组和对象的拷贝。其实使内置对象JSON虽然简答,但不能将对对象的方法深拷贝,因此使用递归的方式就是最实用的,本文介绍使用递归的方式实现深拷贝的原理及具体实现。

1、实现原理:

使用递归的方式实现数组、对象的深拷贝。

先判断各个字段类型,然后用递归解决嵌套数据。

判断拷贝的要进行深拷贝的是数组还是对象,是数组的话进行数组拷贝,对象的话进行对象拷贝。   

进行深拷贝的不能为空,并且是对象或者是数组。

2、具体实现:

function deepClone(obj){
  let objClone =  Array.isArray(obj) ? [] : {};
  if (obj && typeof obj === 'object') {
    for(let key in obj){
      if (obj[key] && typeof obj[key] === 'object'){ //判断对象的这条属性是否为对象
        objClone[key] = deepClone(obj[key]); //若是对象进行嵌套调用
      }else{
        objClone[key] = obj[key]
      }
    }
  }
  return objClone; //返回深度克隆后的对象
}

以上就是使用递归的方式实现深拷贝的原理及具体实现,希望能对你有所帮助。更多js学习推荐:js教程

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

底部广告图