JavaScript深拷贝实现_javascript对象操作

深拷贝通过递归复制对象所有层级实现完全独立。1. JSON.parse(JSON.stringify())适用于纯数据但不支持函数、Date等;2. 手动递归可处理多种类型并解决循环引用;3. structuredClone()为现代API,简洁且内置支持复杂类型与循环引用,选择方案需根据环境与需求决定。

javascript深拷贝实现_javascript对象操作

JavaScript中实现深拷贝的核心在于彻底复制对象及其所有嵌套属性,使新对象与原对象完全独立。浅拷贝只能复制第一层属性,而深拷贝能递归复制所有层级,避免修改副本影响原数据。

1. 使用 JSON.parse(JSON.stringify())

这是最简单的深拷贝方法,适用于大多数纯数据对象:

只处理可序列化数据(如数组、普通对象、基本类型) 无法处理函数、undefined、Symbol、Date、RegExp 等特殊类型 会忽略原型链上的属性示例:

const obj = { a: 1, b: { c: 2 } };const deepCopy = JSON.parse(JSON.stringify(obj));obj.b.c = 3;console.log(deepCopy.b.c); // 输出 2,说明已分离

2. 手动递归实现深拷贝函数

通过类型判断和递归调用,可以处理更多数据类型:

先判断是否为 null 或非对象类型,直接返回 对数组和普通对象分别处理 识别 Date、RegExp 等内置对象并特殊处理 注意循环引用问题,需用 WeakMap 记录已拷贝对象基础实现:

function deepClone(obj, hash = new WeakMap()) {  if (obj == null || typeof obj !== 'object') return obj;  if (hash.has(obj)) return hash.get(obj); // 防止循环引用  let result;  if (obj instanceof Date) result = new Date(obj);  else if (obj instanceof RegExp) result = new RegExp(obj);  else result = Array.isArray(obj) ? [] : {};  hash.set(obj, result);  for (let key in obj) {    if (obj.hasOwnProperty(key)) {      result[key] = deepClone(obj[key], hash);    }  }  return result;}

3. 利用现代浏览器 API:structuredClone

Chrome 98+ 和新版 Node.js 支持的原生深拷贝方法:

立即学习“Java免费学习笔记(深入)”;

支持日期、正则、数组、嵌套对象等常见类型 自动处理循环引用 使用简单,一行代码完成示例:

const original = { date: new Date(), data: { x: 1 } };const copy = structuredClone(original);copy.data.x = 2;console.log(original.data.x); // 输出 1

基本上就这些。选择哪种方式取决于你的环境和需求。兼容老浏览器就用递归方案,追求简洁且环境支持可用 structuredClone,临时调试可以用 JSON 方法但要注意限制。不复杂但容易忽略细节。

以上就是JavaScript深拷贝实现_javascript对象操作的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1540424.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 12:26:11
下一篇 2025年12月21日 12:26:29

相关推荐

  • JavaScript严格模式使用_javascript语法规范

    严格模式通过”use strict”启用,可全局或局部应用。它禁止意外创建全局变量、删除变量或函数、重复参数名、八进制字面量,限制保留字使用,并使函数中this为undefined而非全局对象,有助于发现错误、提升性能和代码规范性,现代模块系统默认采用。 JavaScript…

    2025年12月21日
    000
  • JavaScript DOM操作_javascript网页交互

    DOM是浏览器解析HTML生成的树状结构,JavaScript通过它实现网页交互。首先利用document.getElementById、querySelector等方法获取元素,推荐使用支持CSS选择器的querySelector系列。获取后可修改textContent或innerHTML更新内容…

    2025年12月21日
    000
  • 数据可视化技术选型_D3.js与ECharts的对比

    D3.js适合高度定制化和复杂交互的可视化需求,提供灵活的底层控制,但学习成本高、开发效率低;ECharts则侧重开箱即用,支持丰富图表类型和快速配置,适合业务系统快速交付,但定制性较弱。选型应根据项目对灵活性、开发成本和视觉独特性的实际要求权衡。 在数据可视化领域,D3.js 和 ECharts …

    2025年12月21日
    000
  • javascript_如何实现代码分割

    代码分割通过拆分脚本按需加载提升性能。使用动态import实现异步加载,结合Webpack等工具自动生成分块,支持路由级分割、第三方库分离和条件加载。React中可用lazy+Suspense实现组件懒加载,并通过webpackPrefetch预加载模块,优化用户体验。配置splitChunks可提…

    2025年12月21日
    000
  • javascript_如何实现自动化部署

    JavaScript项目自动化部署通过CI/CD工具实现,1. 使用GitHub Actions等平台,在代码提交后自动触发流程,如通过.yaML文件定义构建、测试、部署步骤;2. 利用npm脚本完成lint、test、build等自动化打包;3. 静态网站可部署至Vercel或用rsync同步服务…

    2025年12月21日
    000
  • JavaScript原型链剖析_JavaScript面向对象编程

    JavaScript通过原型链实现面向对象编程,每个对象都有指向其原型的内部链接,属性查找会沿原型链向上追溯直至null;函数的prototype属性用于构建实例的原型链,__proto__(或Object.getPrototypeOf)反映对象的原型连接,constructor默认指向构造函数,继…

    2025年12月21日
    000
  • JavaScript日期处理_javascript时间操作

    JavaScript的Date对象用于处理日期和时间,可创建当前或指定时间实例。通过new Date()生成日期,支持时间字符串、年月日时分秒参数及时间戳输入。获取日期信息使用getFullYear()、getMonth()(0-11)、getDate()、getDay()等方法。可通过set系列方…

    2025年12月21日
    000
  • 多环境配置管理_开发测试生产环境的切换

    多环境配置管理需分离差异项并自动化控制。1. 分离数据库、密钥、日志等环境特有配置;2. 使用application-{env}.yml文件按环境划分;3. 通过spring.profiles.active指定激活环境;4. 敏感信息用环境变量注入提升安全与灵活;5. CI/CD中自动选配并校验配置…

    2025年12月21日
    000
  • JavaScriptJSON数据处理_JavaScript前后端交互

    JSON是前后端交互常用格式,JavaScript通过JSON.parse()和JSON.stringify()实现对象与字符串转换,结合Fetch API可高效传输数据,需注意合法格式、请求头、跨域及参数传递规范,建议约定统一接口结构并校验数据。 前后端交互中,JSON 是最常用的数据格式之一。J…

    2025年12月21日
    000
  • 渲染性能优化_减少不必要的组件重渲染

    组件重渲染由状态或属性变化触发,即使值未变但引用改变也会导致更新,造成性能损耗。使用 React.memo 可缓存函数组件,仅当 props 变化时重渲染,配合自定义比较逻辑可优化复杂对象判断。避免在 JSX 中创建内联函数或对象,应通过 useCallback 缓存函数、useMemo 缓存计算结…

    2025年12月21日
    000
  • javascript_编译器工作原理

    JavaScript虽为解释型语言,但现代引擎通过JIT技术实现类似编译的流程:1. 解析阶段将源码转为AST;2. 编译与优化阶段对热点代码进行JIT编译并优化;3. 执行阶段运行代码并管理执行上下文与异步操作;4. 垃圾回收阶段自动清理无用内存。 JavaScript 本身是一种解释型语言,通常…

    2025年12月21日
    000
  • JavaScript代码压缩_javascript打包优化

    前端性能优化需通过打包与压缩减少文件体积和请求次数。1. 使用Webpack、Vite或Rollup等工具合并模块,实现高效打包。2. 启用Terser进行JS压缩,去除空格、注释并混淆变量名,减小文件大小。3. 采用代码分割与懒加载,按需加载资源,降低首包体积。4. 利用Tree Shaking清…

    2025年12月21日
    000
  • JavaScript正则表达式指南_javascript文本处理

    正则表达式是JavaScript中处理文本的强大工具,用于字符串匹配、查找、替换和分割;可通过字面量或构造函数创建,支持i(忽略大小写)、g(全局匹配)、m(多行模式)等修饰符;常用元字符包括.、d、w、s、^、$、*、+、?、{n}、[]和(),可组合构建复杂模式;结合match、search、r…

    2025年12月21日
    000
  • JavaScript数据验证_javascript表单处理

    %ignore_a_1%表单验证能提供实时反馈、减轻服务器压力、提升交互体验,常见验证包括必填检查、邮箱格式(正则匹配)、密码强度(长度与复杂度)及手机号验证,确保数据规范安全。 表单数据验证是前端开发中非常重要的一环,JavaScript 能在用户提交数据前检查输入内容是否符合要求,减少无效请求,…

    2025年12月21日
    000
  • javascript_V8引擎的垃圾回收机制

    V8引擎采用分代回收策略,新生代用Scavenge算法快速复制存活对象,老生代用标记-清除与标记-整理解决内存碎片;通过增量、并发和并行技术降低GC停顿,提升性能。 V8引擎是Google开发的高性能JavaScript引擎,广泛应用于Chrome浏览器和Node.js中。它不仅负责解析和执行Jav…

    2025年12月21日
    000
  • 深浅拷贝实现原理_javascript对象操作

    浅拷贝只复制对象第一层属性,引用类型共享内存,修改嵌套对象会影响原对象;深拷贝递归复制所有层级,生成完全独立的对象。常用浅拷贝方法有Object.assign、扩展运算符;深拷贝可用JSON.parse(JSON.stringify())或递归实现,但前者不支持函数、undefined等,后者更灵活…

    2025年12月21日
    000
  • JavaScript闭包原理详解_JavaScript核心概念解析

    闭包是函数与其词法作用域的组合,当内部函数访问外部函数变量时形成,即使外部函数执行完毕,变量仍保留在内存中。例如,function outer() { let name = “Alice”; return function inner() { console.log(name…

    2025年12月21日
    000
  • javascript_异步编程的几种方式

    JavaScript异步编程核心是避免阻塞主线程,主要方式有:1.回调函数易导致回调地狱;2.Promise通过链式调用改善结构;3.async/await以同步风格提升可读性;4.Generator需配合库使用,现少用;5.事件循环中微任务(如Promise)优先于宏任务(如setTimeout)…

    2025年12月21日
    000
  • SolidJS 信号更新指南:深入理解引用相等性与确保 UI 响应

    在 solidjs 中,直接修改 createsignal 管理的数组或对象并重新设置,可能导致 ui 不更新。这是因为 solidjs 信号内部通过引用相等性检查来判断值是否变化。当修改原有对象并设置回去时,引用未变,信号认为值未更新。本文将详细解释此机制,并提供两种解决方案:创建新数组/对象进行…

    2025年12月21日
    000
  • JavaScript中针对特定容器内图片进行动画处理的教程

    本教程详细阐述了如何在javascript中精准选择并动画化特定html `div`容器内的图片,同时避免影响页面上其他图片。我们将探讨三种核心dom选择方法:`getelementsbyclassname`、`getelementsbytagname`与`getelementsbyclassnam…

    2025年12月21日 好文分享
    000

发表回复

登录后才能评论
关注微信