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

招聘网有哪些网站比较好电商网站开发背景

招聘网有哪些网站比较好,电商网站开发背景,昆明汽车建站网站模板,外贸可以什么网站做JavaScript 对象复制:浅拷贝与深拷贝使用说明 在 JavaScript 中,对象复制分为 浅拷贝 和 深拷贝,两者的核心区别在于是否递归复制嵌套的引用类型属性。以下是详细说明和示例: 一、浅拷贝(Shallow Copy) 特…

JavaScript 对象复制:浅拷贝与深拷贝使用说明

在 JavaScript 中,对象复制分为 浅拷贝 和 深拷贝,两者的核心区别在于是否递归复制嵌套的引用类型属性。以下是详细说明和示例:


一、浅拷贝(Shallow Copy)

特点:仅复制对象的第一层属性,若属性是引用类型(如对象、数组),则拷贝的是引用地址。修改嵌套的引用属性会影响原对象。

常用方法:
  1. Object.assign()

    javascript

    const obj = { a: 1, b: { c: 2 } };
    const shallowCopy = Object.assign({}, obj);
    shallowCopy.b.c = 99; // 原对象的 obj.b.c 也会变为 9
    或者
    const shallowCopy = {};
    Object.assign(shallowCopy, obj);也可以复制 reactive 或 ref 创建的响应式对象
    const refObj = ref({});
    Object.assign(refObj.value, proxyObj);
    
  2. 展开运算符 ...

    javascript

    const obj = { a: 1, b: { c: 2 } };
    const shallowCopy = { ...obj };
  3. 数组浅拷贝

    javascript

    const arr = [1, 2, { d: 3 }];
    const newArr = arr.slice(); // 或 [...arr], Array.from(arr)
适用场景:
  • 对象属性无嵌套引用类型。

  • 需要快速复制且性能敏感的场景。


二、深拷贝(Deep Copy)

特点:完全复制对象及其所有嵌套属性,新旧对象完全独立,互不影响。

常用方法:
  1. JSON.parse(JSON.stringify())

    javascript

    const obj = { a: 1, b: { c: 2 }, d: new Date() };
    const deepCopy = JSON.parse(JSON.stringify(obj));如果是 reactive 或 ref 创建的响应式对象,先通过 toRaw 转为 普通对象,再进行拷贝。
    例如:
    const deepCopy = JSON.parse(JSON.stringify(toRaw(proxyObj))); // deepCopy 为普通对象
    const deepCopy = reactive(JSON.parse(JSON.stringify(toRaw(proxyObj)))); // deepCopy 为 reactive 响应式对象 Proxy(Object)
    const deepCopy = ref(JSON.parse(JSON.stringify(toRaw(proxyObj)))); // deepCopy 为ref响应式对象 RefImpl
    

    局限性

    • 忽略 undefined、函数、Symbol。

    • 破坏特殊对象(如 Date 转为字符串,RegExp 转为空对象)。

    • 无法处理循环引用。

  2. structuredClone()(现代浏览器/Node.js 17+)

    javascript

    const obj = { a: 1, b: { c: 2 } };
    const deepCopy = structuredClone(obj); // 支持更多类型,如 Date、Set、Map如果是 reactive 或 ref 创建的响应式对象,先通过 toRaw 转为 普通对象,再进行拷贝。
    例如:
    const deepCopy = structuredClone(toRaw(proxyObj)); // deepCopy 为普通对象
    const deepCopy = reactive(structuredClone(toRaw(proxyObj))); // deepCopy 为 reactive 响应式对象 Proxy(Object)
    const deepCopy = ref(structuredClone(toRaw(proxyObj))); // deepCopy 为ref响应式对象 RefImpl
    
  3. Lodash 的 cloneDeep()

    javascript

    import { cloneDeep } from 'lodash';
    const obj = { a: 1, b: { c: 2 } };
    const deepCopy = cloneDeep(obj); // 处理复杂对象(函数、循环引用等)
  4. 手动递归实现

    javascript

    function deepClone(source, map = new WeakMap()) {if (source === null || typeof source !== 'object') return source;if (map.has(source)) return map.get(source); // 解决循环引用const target = Array.isArray(source) ? [] : {};map.set(source, target);for (const key in source) {if (source.hasOwnProperty(key)) {target[key] = deepClone(source[key], map);}}return target;
    }
适用场景:
  • 对象包含多层嵌套引用。

  • 需要完全独立副本(如状态管理、撤销操作)。


三、如何选择?

方法类型优点缺点
Object.assign浅拷贝简单快速无法处理嵌套引用
JSON 序列化深拷贝原生支持丢失特殊类型,无法处理循环引用
structuredClone深拷贝支持更多类型兼容性要求(IE 不支持)
Lodash cloneDeep深拷贝功能全面需引入第三方库

四、注意事项

  1. 循环引用:手动实现或第三方库需处理对象间的循环引用。

  2. 特殊类型:根据数据类型选择方法(如 structuredClone 支持 Date、Map 等)。

  3. 性能:深拷贝对大型对象有较高开销,优先考虑浅拷贝。


总结

  • 浅拷贝:用 Object.assign 或 ...,适合简单对象。

  • 深拷贝:优先使用 structuredClone 或 Lodash,复杂场景手动实现需谨慎。

通过合理选择拷贝方式,可避免数据意外修改,提升代码健壮性。

http://www.dtcms.com/wzjs/837482.html

相关文章:

  • 阿里云网站建设基本流程百度一下就知道官网
  • 二手交易网站建设目标wordpress 弹出对话框
  • 网站建设客户合同拼多多怎么开店
  • 找单位做网站需要注意什么论坛推广工具
  • 做网站有哪个软件好怎么让百度多收录网站
  • 应聘网站开发的自我介绍企业管理软件系统网
  • 个人直播网站怎么做网站建设首选
  • 高密制作网站网络舆情监测中心
  • 湖南优化网站建设网站设置右击不了如何查看源代码
  • 可以去非菲律宾做游戏网站吗自己做游戏需要学什么
  • 成都服装网站建设聊城手机网站制作
  • 深圳专业网站开发网站建设哪家好知道
  • 商场网站设计山东聊城建设学校怎么样
  • dede手机网站模板下载数学网站怎么做的
  • 沈阳网站开发外包无锡企业建设网站公司
  • 龙华网站建设方案书例文网站建设与管理的未来规划
  • 外贸网站做开关的哪个好石家庄网站建设推广报价
  • 外贸建站系统源码wordpress固定链接出错
  • 设计公司网站时什么是重要的浙江建设工程信息网高工评选
  • 网站建设技术的发展为什么做可信网站
  • 前端网站论文.加强网站安全建设
  • 做打鱼网站需要多少钱网络服务禁用后如何启动
  • asp制作网站教程梵克雅宝官网手链报价
  • 北京网站代理备案安徽合肥制作网站公司
  • 2昌平区网站建设seo整站优化+WordPress
  • 企业网站管理宝塔安装wordpress不成功
  • 选择锦州网站建设网站logo做黑页
  • 网站建设精准精细快速深圳网页设计兴田德润i优惠吗
  • 南通免费网站建设炫酷个人网站
  • 云主机怎么装网站汾阳做网站