当前位置: 首页 > news >正文

开发电商网站要多少钱网站模板

开发电商网站要多少钱,网站模板,音乐网站开发案例,网站死链接是什么一、区别:像“复印文件” vs “创建副本文件” 1. 浅拷贝(Shallow Copy) 动作:只复制文件的第一页,其他页用“贴标签”指向原文件。结果: 修改第一层属性不影响原对象,但修改嵌套对象会同时改…

一、区别:像“复印文件” vs “创建副本文件”

1. 浅拷贝(Shallow Copy)
  • 动作:只复制文件的第一页,其他页用“贴标签”指向原文件。
  • 结果
    修改第一层属性不影响原对象,但修改嵌套对象会同时改变原对象和拷贝对象。
  • 例子
    const original = { a: 1, b: { c: 2 } };
    const shallowCopy = { ...original }; // 展开运算符(浅拷贝)shallowCopy.a = 100;    // 原对象不变:original.a = 1
    shallowCopy.b.c = 200;  // 原对象也被修改:original.b.c = 200
    
2. 深拷贝(Deep Copy)
  • 动作:把文件每一页都完整复印一份,完全独立。
  • 结果
    修改拷贝对象的任何属性都不会影响原对象。
  • 例子
    const original = { a: 1, b: { c: 2 } };
    const deepCopy = JSON.parse(JSON.stringify(original)); // 深拷贝deepCopy.a = 100;       // 原对象不变:original.a = 1
    deepCopy.b.c = 200;     // 原对象不变:original.b.c = 2
    

二、如何实现深拷贝?

方法1:JSON 序列化(简单但局限)
  • 代码
    function simpleDeepCopy(obj) {return JSON.parse(JSON.stringify(obj));
    }
    
  • 缺点
    • 无法拷贝函数、undefinedSymbol
    • 会丢失 Date 对象(转成字符串)、正则表达式(转成空对象)。
    • 无法处理循环引用(如 obj.self = obj)。

方法2:递归克隆(手动实现完整版)

代码步骤分解

function deepClone(obj, cache = new WeakMap()) {// 1. 处理基本类型和 null/undefinedif (obj === null || typeof obj !== 'object') return obj;// 2. 处理循环引用(避免无限递归)if (cache.has(obj)) return cache.get(obj);// 3. 处理特殊对象类型let clone;if (obj instanceof Date) {clone = new Date(obj); // 克隆日期} else if (obj instanceof RegExp) {clone = new RegExp(obj); // 克隆正则} else if (obj instanceof Map) {clone = new Map(Array.from(obj, ([key, val]) => [key, deepClone(val, cache)])); // 克隆Map} else if (obj instanceof Set) {clone = new Set(Array.from(obj, val => deepClone(val, cache))); // 克隆Set} else if (Array.isArray(obj)) {clone = []; // 克隆数组} else {clone = Object.create(Object.getPrototypeOf(obj)); // 克隆普通对象(保留原型链)}// 4. 缓存当前对象,防止循环引用cache.set(obj, clone);// 5. 递归拷贝所有属性for (const key in obj) {if (obj.hasOwnProperty(key)) {clone[key] = deepClone(obj[key], cache);}}return clone;
}

方法3:使用现成库(推荐实际开发使用)
  • Lodash
    import _ from 'lodash';
    const deepCopy = _.cloneDeep(original);
    
  • 优点:处理了所有边界情况(函数、循环引用、特殊对象等)。

三、不同场景选择建议

场景推荐方法
简单对象(无函数、日期)JSON.parse(JSON.stringify())
复杂对象(含特殊类型)Lodash 的 cloneDeep
需要手动控制递归克隆实现

总结

  • 浅拷贝:只复制表层,嵌套对象共享。
  • 深拷贝:完全独立副本,彻底隔离。
  • 实际开发:优先使用 Lodash 的 cloneDeep,避免重复造轮子!
http://www.dtcms.com/a/430132.html

相关文章:

  • 网站开发用户需求说明书宁波网站搭建定制非模板网站建设
  • 利用黑群晖做网站婚礼策划公司排名
  • 网站的反爬一般怎样做建筑公司企业愿景文案
  • 如何在自己网站上做支付宝吗深圳市网络营销公司
  • 淄博网站排名优化报价上海某家具网站建设方案
  • 秦皇岛pc端网站建设网络推广优化培训
  • 国外红色企业网站中国企业网信息查询系统
  • 如何用ftp登陆网站网站建设jiage
  • h5建设网站教程wordpress 修改时间
  • 衡阳网站建设公司如何查找网站根目录
  • 网站开发毕业设计源码网站设计展示
  • 比较容易做流量的网站做网站要会编程么
  • 龙岗网站多少钱今天的热搜榜
  • 青岛网站权重提升衡水龙腾网站建设
  • 如何制作网站专题中国工程建设监理协会网站
  • 十堰网站建设公司电话公司网站建设注意
  • 游戏网站做关键字wordpress 淘宝客网站
  • 优秀材料写作网站idstore wordpress
  • 8个页面的网站怎么做网络营销策略文献综述
  • api in wordpressseo技术大师
  • 电商网站开发流程图桂林欣梦网络
  • 如何做实验室网站做网站的流程是什么
  • 上海网站建设口碑最好的公司福州网站开发si7.cc
  • win10 电脑做网站服务器吗js制作简单的公司首页
  • 网站建设 教学大纲专门做mod的网站
  • 代做通一样的网站网页网站培训班
  • 图书网站建设昆明大型网页开发企业
  • 在线营销推广西安seo交流
  • 男女生做羞羞网站做健身俱乐部网站的目的和意义
  • uml电子商务网站建设文档免费简历模板下载word