js深拷贝与浅拷贝详解以及例子

43 篇文章 0 订阅

深拷贝与浅拷贝

什么是浅拷贝

浅拷贝只拷贝一层,更深层次对象级别的只会拷贝引用(地址)

  1. 第一种浅拷贝方法(slice)
var arr1=[1,2]
var arr2=arr1.slice();
arr1[0]=100
console.log(arr1);//[100,2]
console.log(arr2);//[1,2]
  1. 第二种浅拷贝方法(concat)
var arr1=[1,2]
var arr2=arr1.concat();
arr1[0]=100
console.log(arr1);//[100,2]
console.log(arr2);//[1,2]
  1. 第三种浅拷贝方法(扩展运算符…)
const obj1 = { a : 1, b : {c:1}}
var k = {...obj1}
obj1.b.c = 100000
console.log(obj1 );//{a: 1,b: {c: 100000}}
console.log(k);//{a: 1,b: {c: 100000}}
  1. 第四种浅拷贝方法(forEach)
   var arr1 = [1, { a: 2 }]
   var arr2 = []
   arr1.forEach(item => {
       arr2.push(item)
   })

   arr1[1].a = 1000
   console.log(arr1);
   console.log(arr2);
  1. 第五种浅拷贝方法(for of)
  var arr1 = [1, { a: 2 }]
  var arr2 = []
  for (item of arr1) {
      arr2.push(item)
  }

  arr1[1].a = 1000
  console.log(arr1);
  console.log(arr2);
  1. 第六种浅拷贝方法(for in)
  var arr1 = [1, { a: 2 }]
  var arr2 = []
  for (key in arr1) {
      arr2.push(arr1[key])
  }

  arr1[1].a = 1000
  console.log(arr1);
  console.log(arr2);
  1. 第七种浅拷贝方法(for循环)
 var arr1 = [1, { a: 2 }]
 var arr2 = []
 for (var i = 0; i < arr1.length; i++) {
     arr2.push(arr1[i])
 }

 arr1[1].a = 1000
 console.log(arr1);
 console.log(arr2);

什么是深拷贝

每一层都拷贝,最后拷贝出来的是一个全新的,和之前的完全没关系

  1. 第一种深拷贝方法
  const obj1 = { a : 1, b : {c:1}}
  const obj2 = JSON.parse(JSON.stringify(obj1));
  obj1.b.c = 100;
  console.log(obj1);
  console.log(obj2); 
	注意:但是这个方法只有可以转成JSON格式的对象才可以这样用,像function没办法转成JSON,RegExp对象是无法通过这种方式深拷贝
  1. 第二种深拷贝(封装好的函数)
 function deepCopy(newobj, oldobj) {
     for (var k in oldobj) {
         // 判断我们的属性值属于那种数据类型
         // 1. 获取属性值  oldobj[k]
         var item = oldobj[k];
         // 2. 判断这个值是否是数组
         if (item instanceof Array) {
             newobj[k] = [];
             deepCopy(newobj[k], item)
         } else if (item instanceof Object) {
             // 3. 判断这个值是否是对象
             newobj[k] = {};
             deepCopy(newobj[k], item)
         } else {
             // 4. 属于简单数据类型
             newobj[k] = item;
         }

     }
 }
  1. 第三种深拷贝方法
function deepClone(obj = {}) {
    if (typeof obj !== 'object' || obj == null) {
        // obj 是 null ,或者不是对象和数组,直接返回
        return obj
    }

    // 初始化返回结果
    let result
    if (obj instanceof Array) {
        result = []
    } else {
        result = {}
    }

    for (let key in obj) {
        // 保证 key 不是原型的属性
        if (obj.hasOwnProperty(key)) {
            // 递归调用!!!
            result[key] = deepClone(obj[key])
        }
    }

    // 返回结果
    return result
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值