js 深拷贝

一,对象深拷贝的几种方法

1. 使用递归的方式实现深拷贝

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;
}

2. 通过JSON对象实现深拷贝 

function deepClone2(obj) {
  let _obj = JSON.stringify(obj);
  return JSON.parse(_obj);
}
js 深拷贝

3. 通过Object.assign()拷贝

js 深拷贝

4.实现思路:

  1. 在函数内部定义一个变量,来存储拷贝出来的内容
  2. 首先判断传进来的参数是否是引用数据类型,不是引用数据类型返回参数(这里面用的是typeof判断)
  3. 接下来用instanceof判断是数组还是对象,并且将定义的变量赋值为空数组或者空对象
  4. 接下来对传进来的参数进行枚举,对枚举出来的属性进行判断递归
// 深拷贝
function deepClone(obj) {
            if(typeof obj !=="object" || obj == null){
                return obj
            }
            let res
            if(obj instanceof Array){
                res = []
            }else{
                res = {}
            }
            for(key in obj){
                if(obj.hasOwnProperty(key)){
                    res[key] = deepClone(obj[key])
                }
            }
            return res
        }

 二,数组深拷贝的几种方法

1. concat(arr1, arr2,....)

js 深拷贝

2. slice(idx1, idx2)

参数可以省略

1)没有参数是拷贝数组

2)只有一个参数是从该位置起到结束拷贝数组元素

3)两个参数,拷贝从起始位置到结束位置的元素(不包含结束位置的元素:含头不含尾)

js 深拷贝
  1. 在函数内部定义一个变量,来存储拷贝出来的内容
  2. 首先判断传进来的参数是否是引用数据类型,不是引用数据类型返回参数(这里面用的是typeof判断)
  3. 接下来用instanceof判断是数组还是对象,并且将定义的变量赋值为空数组或者空对象
  4. 接下来对传进来的参数进行枚举,对枚举出来的属性进行判断递归

本资源由随笔博客发布。发布者:五维国度,转载请注明出处:http://blog.suibi.site/archives/4388


本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

(0)
上一篇 2023年 3月 9日 下午7:40
下一篇 2023年 3月 29日 上午10:40

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

联系我们

在线咨询: QQ交谈

邮件:jctestxcx@163.com

关注微信