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

爱站工具有加超人下拉系统西安官网seo技术

爱站工具有加超人下拉系统,西安官网seo技术,河东网站建设公司,今日头条移动建站工具js 对象深拷贝 今天遇到一个bug ,子组件页面修改了内容,但是按了取消保存按钮,没有将数据传回父组件的,但是父组件的数据改了,原因是通过子组件接受父组件的参数对象层级深没有做深拷贝的原因。 在 JavaScript 中&…

js 对象深拷贝


今天遇到一个bug ,子组件页面修改了内容,但是按了取消保存按钮,没有将数据传回父组件的,但是父组件的数据改了,原因是通过子组件接受父组件的参数对象层级深没有做深拷贝的原因。

在 JavaScript 中,深拷贝是指复制一个对象及其所有嵌套对象的完整副本,而不是仅仅复制引用。以下是几种实现深拷贝的方法:

方法 1:使用 JSON.parseJSON.stringify

这是最简单的方法,但有一些限制(例如,无法拷贝函数、undefinedSymbol 等)。

const obj = { a: 1, b: { c: 2 } };
const deepCopy = JSON.parse(JSON.stringify(obj));console.log(deepCopy); // { a: 1, b: { c: 2 } }

注意

  • 无法拷贝函数、undefinedSymbol
  • 不支持循环引用。

方法 2:使用递归实现深拷贝

手动实现一个递归函数来处理对象和数组。

function deepClone(obj) {if (obj === null || typeof obj !== "object") {return obj; // 基本类型直接返回}// 创建一个新对象或数组const copy = Array.isArray(obj) ? [] : {};for (const key in obj) {if (obj.hasOwnProperty(key)) {copy[key] = deepClone(obj[key]); // 递归拷贝}}return copy;
}const obj = { a: 1, b: { c: 2 }, d: [3, 4] };
const deepCopy = deepClone(obj);console.log(deepCopy); // { a: 1, b: { c: 2 }, d: [3, 4] }

方法 3:使用 lodash

lodash 是一个流行的 JavaScript 工具库,其中的 cloneDeep 方法可以轻松实现深拷贝。

import _ from "lodash";const obj = { a: 1, b: { c: 2 }, d: [3, 4] };
const deepCopy = _.cloneDeep(obj);console.log(deepCopy); // { a: 1, b: { c: 2 }, d: [3, 4] }

优点

  • 支持复杂对象(如循环引用)。
  • 可靠且易用。

方法 4:使用 structuredClone(现代浏览器支持)

structuredClone 是一种原生方法,用于深拷贝对象。

const obj = { a: 1, b: { c: 2 }, d: [3, 4] };
const deepCopy = structuredClone(obj);console.log(deepCopy); // { a: 1, b: { c: 2 }, d: [3, 4] }

优点

  • 支持循环引用。
  • 原生方法,性能较好。

注意

  • 仅在现代浏览器和 Node.js 17+ 中支持。

方法 5:使用 Object.create 和递归

通过 Object.create 创建新对象,并递归拷贝属性。

function deepClone(obj) {if (obj === null || typeof obj !== "object") {return obj;}const copy = Object.create(Object.getPrototypeOf(obj));for (const key of Object.keys(obj)) {copy[key] = deepClone(obj[key]);}return copy;
}const obj = { a: 1, b: { c: 2 }, d: [3, 4] };
const deepCopy = deepClone(obj);console.log(deepCopy); // { a: 1, b: { c: 2 }, d: [3, 4] }

总结

  • 简单对象:可以使用 JSON.parse(JSON.stringify(obj)
  • 复杂对象:推荐使用 lodash.cloneDeepstructuredClone
  • 自定义实现:可以使用递归函数处理特殊需求。
http://www.dtcms.com/wzjs/108762.html

相关文章:

  • 家居网站页面设计图片怎么推广游戏代理赚钱
  • 网站设计师培训班搜索引擎竞价广告
  • 微信开放平台与个人网站怎么杭州seo软件
  • 外国高端网站怎么开通百度推广账号
  • wordpress上传媒体武汉seo网站
  • 网站做兼容处理怎么佛山网站优化排名推广
  • 做网站用什么编程语言好百度官方网站下载安装
  • 做采集网站难不网络营销平台有哪些?
  • 效果好的魔站建站系统网页设计html代码大全
  • 湖南郴州人很穷吗优化公司
  • 自做衣服网站网络广告营销方案策划内容
  • 重庆网站seo公司哪家好营销策略ppt
  • 组服务器做网站seo领导屋
  • 网页设计怎么样东莞seo建站公司
  • 网站建设交流完整的网页设计代码
  • 湖南网站制作团队注册百度账号
  • 网站asp模板网络营销毕业论文范文
  • 音乐网站开发教程站长工具seo综合查询广告
  • 安阳手机网站建设网店seo关键词
  • wordpress子主题安全seo优质友链购买
  • 设计9大软件安新seo优化排名网站
  • 网上商城运营推广方案纵横seo
  • 婚庆公司网站建设得多少钱网络精准推广
  • 衡水市网站建设河南网站建设报价
  • 广州大型网站建设抖音信息流广告怎么投放
  • 互联网网站建设营销推广计划怎么写
  • 重庆网站建客户管理系统
  • 网站开发语成都网络推广运营公司
  • 无锡专业网站建设百度指数支持数据下载吗
  • nas wordpress 外网访问成都网站seo推广