JS 手写 深拷贝

本文探讨如何在JavaScript中手写实现深拷贝的方法,详细解释其原理和步骤,以帮助理解对象复制的深层机制。
摘要由CSDN通过智能技术生成

JS 手写 深拷贝

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>

  <body>
    <script>
      var obj1 = {
        name: 'laowang',
        age: 18,
        do: function () {
          console.log('study')
        },
        hobby: ['唱', '跳', 'rap', [1, 2, 3]],
      }

      function checkType(obj) {
        return Object.prototype.toString.call(obj).slice(8, -1).toLowerCase()
      }

      // 深拷贝函数
      function deepClone(obj) {
        // 刚进入函数需要判断 当前要拷贝的值是什么类型
        if (checkType(obj) === 'object') {
          // 如果当前拷贝的是一个对象,则需要定一个新的对象
          var newObj = {}
        } else if (checkType(obj) === 'array') {
          // 如果当前拷贝的是一个数组,则需要定一个新的数组
          var newObj = []
        } else {
          // 如果当前拷贝的值既不是数组也不是对象,则直接返回即可
          return obj
        }

        // 开始拷贝
        // ["唱", "跳", "rap", [1, 2, 3]]

        for (var key in obj) {
          // 在拷贝之前 需要判断当前的obj[key]是一个对象还是数组,如果是对象或数组,则需要重新拷贝 再赋值
          newObj[key] = deepClone(obj[key])
        }

        return newObj
      }

      var obj2 = deepClone(obj1)
      console.log(obj1) // {name: 'laowang', age: 18, hobby: Array(4), do: ƒ}
      console.log(obj2) // {name: 'laowang', age: 18, hobby: Array(4), do: ƒ}
      console.log(obj2 === obj1) // false
      console.log(obj2.hobby === obj1.hobby) // false
      console.log(obj2.hobby[3] === obj1.hobby[3]) // false
    </script>
  </body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值