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

JavaScript 浅拷贝:只复制“第一层”的艺术

JavaScript 浅拷贝只复制“第一层”的艺术 什么是浅拷贝定义浅拷贝是指创建一个新对象这个新对象拥有原对象属性值的精确拷贝。如果属性是基本类型String, Number, Boolean…拷贝的是值。如果属性是引用类型Object, Array…拷贝的是内存地址指针。通俗比喻想象你有一本相册原对象。浅拷贝你复印了相册的封面和目录。对于照片本身你没有重新打印而是把原相册里的照片拿出来放进了新相册。结果如果你在新相册里撕掉一张照片修改引用类型的内部属性原相册里的那张照片也坏了因为它们其实是同一张物理照片。但是如果你给新相册换了一个封面修改第一层基本属性原相册不受影响。 目录️ 图解浅拷贝 vs 深拷贝️ 实现浅拷贝的 4 种主流方法⚠️ 浅拷贝的陷阱什么时候会出问题 总结与选型建议1. ️ 图解浅拷贝 vs 深拷贝假设我们有如下数据结构constoriginal{name:Lingma,// 基本类型info:{// 引用类型age:1,},};✅ 浅拷贝后内存结构Stack (栈) ---------- Heap (堆) | original |----------- ------------------ ---------- | name: Lingma | | info: [Addr A] ---- ------------------ ---------- ------------------ | age: 1 | | copy |----------- ------------------ ------------------ ---------- | name: Lingma | | info: [Addr A] ------^ (指向同一个对象!) ------------------结论original.info和copy.info指向堆中的同一个对象。❌ 深拷贝后内存结构对比参考Stack (栈) ---------- Heap (堆) | original |----------- ------------------ ---------- | name: Lingma | | info: [Addr A] ---- ------------------ ---------- ------------------ | age: 1 | | copy |----------- ------------------ ------------------ ---------- | name: Lingma | | info: [Addr B] ---- ------------------ ------------------ | age: 1 | ------------------结论copy拥有完全独立的内存空间。2. ️ 实现浅拷贝的 4 种主流方法方法一Object.assign()经典常用这是 ES6 之前最常用的浅拷贝方法。它将源对象的所有可枚举属性复制到目标对象。constoriginal{a:1,b:{c:2}};constcopyObject.assign({},original);// 测试基本类型copy.a99;console.log(original.a);// 1 ✅ 互不影响// 测试引用类型copy.b.c99;console.log(original.b.c);// 99 原数据被修改注意第一个参数{}是目标对象必须传空对象否则original自身会被修改。方法二展开运算符...现代首选ES6 引入的语法糖代码更简洁可读性更高。constoriginal{a:1,b:{c:2}};constcopy{...original};// 效果同 Object.assigncopy.b.c99;console.log(original.b.c);// 99 对于数组的浅拷贝constarr[1,2,[3,4]];constnewArr[...arr];// 或者constnewArr2arr.slice();// 或者constnewArr3Array.from(arr);方法三Array.prototype.slice()/concat()数组专用在 ES6 之前这是数组浅拷贝的标准做法。constarr[1,2,3];constcopy1arr.slice();constcopy2[].concat(arr);方法四手写浅拷贝函数面试/定制需求如果需要兼容旧环境或处理特殊逻辑可以手写。functionshallowClone(obj){if(objnull||typeofobj!object){returnobj;}// 判断是数组还是对象constcloneObjArray.isArray(obj)?[]:{};for(letkeyinobj){if(obj.hasOwnProperty(key)){cloneObj[key]obj[key];// 直接赋值引用类型拷贝地址}}returncloneObj;}3. ⚠️ 浅拷贝的陷阱什么时候会出问题浅拷贝最大的风险在于嵌套对象。❌ 事故现场constuser{name:Lingma,settings:{theme:dark,notifications:true,},};// 浅拷贝constnewUser{...user};// 用户修改设置newUser.settings.themelight;console.log(user.settings.theme);// light // 糟糕原用户的设置也被改了✅ 如何避免如果只有一层嵌套使用浅拷贝完全没问题性能最好。如果有多层嵌套使用深拷贝structuredClone,JSON.parse/stringify, LodashcloneDeep。或者使用不可变数据库如 Immer, Immutable.js它们通过结构共享实现了高效的“看似可变实则不可变”。4. 总结与选型建议方法适用场景优点缺点{ ...obj }对象浅拷贝语法简洁现代标准仅浅拷贝兼容性需 babelObject.assign对象浅拷贝/合并兼容性好可合并多个对象语法稍啰嗦[...arr]数组浅拷贝简洁速度快仅适用于数组/可迭代对象arr.slice()数组浅拷贝经典写法兼容 IE语义不如展开运算符清晰 博主寄语浅拷贝不是“低级”的拷贝而是高性能的拷贝。在 React/Vue 的状态管理中如果状态层级不深浅拷贝配合不可变思维Immutability是最佳实践。记住原则一层用浅多层用深。数组展开最香对象合并 assign。引用类型要小心修改之前想清楚。希望这篇文档能帮你彻底掌握浅拷贝如果有疑问欢迎在评论区留言。喜欢这篇文章吗记得点赞、收藏、转发哦❤️

相关文章:

JavaScript 浅拷贝:只复制“第一层”的艺术

📋 JavaScript 浅拷贝:只复制“第一层”的艺术 🤔 什么是浅拷贝? 定义: 浅拷贝是指创建一个新对象,这个新对象拥有原对象属性值的精确拷贝。 如果属性是基本类型(String, Number, Boolean…&…...

BarTender模板设计+Java动态传参实战:教你制作可复用的智能标签打印模块

BarTender模板设计与Java动态传参实战:构建智能标签打印系统 在工业自动化、物流管理和资产追踪等领域,标签打印系统往往是业务流转的关键环节。传统打印方案常面临一个核心矛盾:业务人员需要频繁调整标签格式和内容,而开发人员则…...

AI设计圣经:用规则引擎提升UI/UX设计效率与一致性

1. 项目概述:为AI设计助手打造的UI/UX设计规则圣经如果你和我一样,既是开发者,又经常需要和设计师协作,或者干脆自己上手用Figma画界面,那你肯定遇到过这样的场景:脑子里有个不错的想法,打开Fig…...

AI落地最后一公里难题如何破局?SITS2026同期活动深度复盘(2026真实战报首曝)

更多请点击: https://intelliparadigm.com 第一章:AI落地最后一公里难题如何破局?SITS2026同期活动深度复盘(2026真实战报首曝) 在SITS2026大会同期举办的「AI工程化攻坚工作坊」中,来自17家头部企业的CTO…...

CANN/TensorFlow HCCL代码示例

代码示例 【免费下载链接】tensorflow Ascend TensorFlow Adapter 项目地址: https://gitcode.com/cann/tensorflow 该代码示例针对TensorFlow 1.15网络,使用默认的全局通信域进行通信。 假设代码文件命名为hccl_test.py。 import tensorflow as tf import…...

基于MPC的以太坊RPC服务:构建去中心化签名与私钥安全管理方案

1. 项目概述:一个去中心化的MPC签名服务最近在跟几个做链上资管和DeFi协议的朋友聊天,大家都在头疼同一个问题:如何安全地管理多签钱包的私钥。传统的多签方案,比如Gnosis Safe,虽然解决了单点故障,但每次交…...

从零搭建一个S3兼容的私有云盘:我用MinIO+Docker的完整实践与踩坑记录

从零搭建一个S3兼容的私有云盘:我用MinIODocker的完整实践与踩坑记录 在个人开发者和小团队的项目中,数据存储需求往往介于简单的本地文件系统和复杂的云服务之间。我们既希望拥有云存储的灵活性和可扩展性,又需要保持数据的私有性和成本可控…...

OpenAI发布MRC超算协议,重塑10万GPU集群通信,AMD等合作推进

每周有9亿人在使用ChatGPT,支撑其运转的系统正在成为核心基础设施。要让AI变得更聪明,企业必须把成千上万块芯片连接在一起协同工作。而芯片之间的数据传输速度直接决定了整个系统的计算效率。OpenAI联合AMD、博通、英特尔、微软和英伟达,通过…...

CANN ops-math Fill算子

Fill 【免费下载链接】ops-math 本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。 项目地址: https://gitcode.com/cann/ops-math 产品支持情况 产品是否支持Ascend 950PR/Ascend 950DT√Atlas A3 训练系列产品/Atlas A3 推理系列产品√A…...

别再让Langchain卡住你的前端!一个FastAPI + SSE的保姆级流式输出教程(附完整可运行代码)

FastAPI SSE实战:打破Langchain流式输出到前端的最后屏障 当ChatGLM3生成的文字在前端页面逐字跳动时,会议室突然安静了。团队花了三周时间尝试解决的"伪流式"问题,此刻被20行Python代码彻底终结。这不是魔法,而是Serv…...

ARGO:本地部署AI智能体,打造私有化多智能体协作平台

1. 项目概述:ARGO,你的本地超级AI智能体如果你和我一样,对AI智能体(Agent)的潜力感到兴奋,但又对数据隐私、高昂的API成本以及云端服务的不可控性心存疑虑,那么ARGO的出现,可能正是我…...

CANN ATC模型转换指南

ATC模型转换指南 【免费下载链接】cann-recipes-harmony-infer 本项目为鸿蒙开发者提供基于CANN平台的业务实践案例,方便开发者参考实现端云能力迁移及端侧推理部署。 项目地址: https://gitcode.com/cann/cann-recipes-harmony-infer ATC是异构计算架构CANN…...

基于AI的自动化代理框架:用自然语言驱动网页操作实践

1. 项目概述与核心价值最近在折腾一些自动化流程,发现很多重复性的网页操作和表单填写工作特别耗时。比如,每天要登录好几个后台系统查看数据、手动下载报表,或者需要定期在某个网站上提交固定的信息。这些操作本身不复杂,但架不住…...

CANN/pypto的expand_clone函数

# pypto.expand_clone 【免费下载链接】pypto PyPTO(发音: pai p-t-o):Parallel Tensor/Tile Operation编程范式。 项目地址: https://gitcode.com/cann/pypto 产品支持情况 产品是否支持Ascend 950PR/Ascend 950DT√Atl…...

对比自行维护多个 API 密钥使用 Taotoken 的管理效率提升

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 对比自行维护多个 API 密钥使用 Taotoken 的管理效率提升 在开发基于大模型的应用时,团队或个人开发者常常需要接入多个…...

告别官方镜像站卡顿:国内镜像源加速下载树莓派系统(Raspberry Pi OS)与常用软件包

告别官方镜像站卡顿:国内镜像源加速下载树莓派系统与常用软件包 对于国内树莓派用户来说,最头疼的莫过于从官方源下载系统镜像和更新软件包时的漫长等待。想象一下,你兴冲冲地买来树莓派准备大展身手,却在第一步——下载系统镜像时…...

CANN/ops-cv算子跨平台迁移指导

算子跨平台迁移指导 【免费下载链接】ops-cv 本项目是CANN提供的图像处理、目标检测相关的算子库,实现网络在NPU上加速计算。 项目地址: https://gitcode.com/cann/ops-cv 本指南介绍算子在多平台间迁移的适配要点与方案。以算子从Atlas A2系列迁移至Ascend …...

基于TwoAI框架构建多智能体对话系统:原理、配置与实战

1. 项目概述:当两个AI开始对话最近在折腾AI应用开发的朋友,可能都遇到过类似的场景:你想测试一个智能客服的对话流,或者想模拟用户与AI助手的多轮交互,但总是一个人扮演两个角色,在同一个聊天窗口里自问自答…...

CANN/ops-transformer FlashAttentionScore算子

FlashAttentionScore 【免费下载链接】ops-transformer 本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。 项目地址: https://gitcode.com/cann/ops-transformer 产品支持情况 产品是否支持Ascend 950PR/Ascend 950DT√Atlas A3 训练…...

数据科学实战:从零构建高质量数据集资源库与预处理指南

1. 项目概述:为什么你需要一个专属的“数据弹药库”在数据科学、机器学习乃至更广阔的AI领域摸爬滚打这些年,我最大的体会是:想法不值钱,数据才是硬通货。你可能有绝妙的算法构思,有清晰的业务逻辑,但如果没…...

【AI原生应用安全红宝书】:SITS2026框架下7大高危攻击面与零信任加固路径

更多请点击: https://intelliparadigm.com 第一章:SITS2026框架演进与AI原生安全范式跃迁 SITS2026(Secure Intelligence Trust Stack 2026)标志着安全架构从“防御叠加”向“智能内生”的根本性转变。其核心不再依赖边界检测与规…...

5大核心技术揭秘:Seraphine如何通过LCU API重塑英雄联盟游戏体验

5大核心技术揭秘:Seraphine如何通过LCU API重塑英雄联盟游戏体验 【免费下载链接】Seraphine 英雄联盟战绩查询工具 项目地址: https://gitcode.com/gh_mirrors/se/Seraphine 在竞技游戏的激烈对抗中,信息差往往是决定胜负的关键因素。Seraphine作…...

别再只盯着告警了:从Pikachu靶场搭建看SRE可观测性的实战落地(含日志与调用链配置)

从Pikachu靶场搭建看SRE可观测性的实战落地 当我们在本地搭建一个Web漏洞练习平台时,往往只关注漏洞利用本身,却忽略了服务运行时的状态感知。最近在配置Pikachu靶场时,我尝试将SRE的可观测性理念应用到这个微型PHP服务中,意外发现…...

SAP ABAP开发避坑:WS_DELIVERY_UPDATE函数调用时,COMMIT和NO_MESSAGES_UPDATE参数到底怎么设?

SAP ABAP开发实战:WS_DELIVERY_UPDATE函数参数组合的黄金法则 在SAP物流模块开发中,WS_DELIVERY_UPDATE函数就像一把瑞士军刀——功能强大但参数复杂。许多ABAP开发者第一次接触这个函数时,往往会被其十余个控制参数弄得晕头转向。更棘手的是…...

6G+AI重塑医疗影像:云边端协同架构与智能诊断实践

1. 项目概述:当6G遇见AI,磁共振影像的“超进化”最近和几位三甲医院影像科的朋友聊天,他们都在为一个问题头疼:磁共振(MRI)检查量越来越大,一个病人动辄几十个序列、上百GB的原始数据&#xff0…...

基于AgentScope与ReMe构建开源AI助手工作站CoPaw实战指南

1. 项目概述:一个开源的个人AI助手工作站最近在折腾AI智能体,发现了一个挺有意思的开源项目,叫CoPaw。简单来说,你可以把它理解成一个“个人AI助手工作站”。它不是某个单一的聊天机器人,而是一个能让你在本地或云端部…...

CANN可变长FlashAttentionV2

aclnnFlashAttentionVarLenScoreV2 【免费下载链接】ops-transformer 本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。 项目地址: https://gitcode.com/cann/ops-transformer 产品支持情况 产品是否支持Ascend 950PR/Ascend 950DT√…...

AI for Science中的分布外泛化:从理论到实践的挑战与应对

1. 项目概述:当AI遇见科学,泛化能力成为“卡脖子”难题最近几年,AI for Science(科学智能)火得一塌糊涂,从预测蛋白质结构的AlphaFold,到加速新材料发现的生成模型,AI正在成为继理论…...

WeChatExporter终极指南:5步解锁你的微信聊天记录备份神器

WeChatExporter终极指南:5步解锁你的微信聊天记录备份神器 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 你是否曾担心重要聊天记录丢失?或是需要…...

基于语义搜索的代码索引工具:从原理到部署实战

1. 项目概述:一个为代码库建立智能索引的利器最近在折腾个人项目和团队协作时,我遇到了一个挺普遍但很头疼的问题:随着代码库规模越来越大,文件越来越多,想要快速找到一个特定的函数定义、某个类的引用,或者…...