ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

js 原生手写深拷贝

2022-02-23 10:04:14  阅读:147  来源: 互联网

标签:obj2 obj name value js key console 手写 拷贝


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></body>
  <script>
    let obj = {
      name: "zhangsan",
      username: 1234,
      password: "fdfe",
      list: [3, 1, 2, [3, 2, 1], { name: "Lisi" }],
      sex: undefined,
      time: new Date(),
      family: {
        name: "王",
      },
      reg: /\d/,
      fn: function () {
        console.log("OK");
      },
    };

    let obj2 = {};
    function clone(obj2, obj) {
      for (let key in obj) {
        let value = obj[key];
        console.log(value);
        if (Object.prototype.toString.call(value) === "[object Array]") {
          obj2[key] = [];
          clone(obj2[key], value);
        } else if (
          Object.prototype.toString.call(value) === "[object Object]"
        ) {
          obj2[key] = {};
          clone(obj2[key], value);
        } else {
          obj2[key] = value;
        }
      }
    }
    clone(obj2, obj);
    obj.family.name = "d";
    obj.name = "dfdf";
    obj.list.push(22);
    obj.list[3].push(1);
    obj2.list[4].name = "111";
    console.log(obj);
    console.log(obj2);
    obj.fn();
    obj2.fn()
  </script>
</html>

标签:obj2,obj,name,value,js,key,console,手写,拷贝
来源: https://blog.csdn.net/Vue1024/article/details/123083392

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有