伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

简简单单在 JavaScript 中克隆对象

来源:本站原创 浏览:41次 时间:2023-07-09
简简单单在 JavaScript 中克隆对象

疯狂的技术宅 前端先锋

翻译:疯狂的技术宅
作者:Angelos Chalaris
来源:30secondsofcode.org
正文共:1093 字
预计阅读时间:5分钟

JavaScript 的原始数据类型(例如number、string、null,undefined 和 boolean)是不可变的,这意味着一旦创建,它们的值就无法更改。但是对象和数组是可变的,允许在创建后修改其值。实际上,这意味着基元是通过值传递的,而对象和数组是通过引用传递的。考虑以下例子:

1let str = 'Hello';2let copy = str;3copy = 'Hi';4// str = 'Hello', copy = 'Hi'56let obj = { a: 1, b: 2 };7let objCopy = obj;8objCopy.b = 4;9// obj = { a: 1, b: 4}, objCopy = { a: 1, b: 4 }

在 obj 中发生的事是该对象是通过引用传递给 objCopy 的,因此修改其中一个变量的值也会影响另一个变量。objCopy 实际上是引用同一对象的别名。我们可以使用多种技术(例如,展开运算符(...)或带有空对象的 Object.assign())来克隆对象,以解决此问题:

1let obj = { a: 1, b: 2};2let clone = { ...obj };3clone.b = 4;4// obj = { a: 1, b: 2}, clone = { a: 1, b: 4 }56let otherClone = Object.assign({}, obj);7otherClone.b = 6;8clone.b = 4;9// obj = { a: 1, b: 2}, otherClone = { a: 1, b: 6 }

这两种解决方案都展示了浅克隆的例子,因为它们适用于外部(浅)对象,但是如果我们嵌套(深)对象,这些对象最终将通过引用传递,从而导致失败。有几种方法可以解决这个问题,其中更简单的方法是用 JSON.stringify() 和 JSON.parse() 处理:

1let obj = { a: 1, b: { c: 2 } };2let clone = JSON.parseJSON.stringify(obj));3clone.b.c = 4;4// obj = { a: 1, b: { c: 2 }}, clone = { a: 1, b: { c: 4 } }

虽然上面的例子有效,但它必须序列化和反序列化整个对象,这可能会严重影响代码的性能,所以它可能不适用于较大的对象或对性能要求很高的项目。

另外,你可以用递归函数来深度克隆对象,并且速度要快得多,例如下面代码中的递归函数。同样,如果你想使用现成的浅克隆函数,则可以这样做:const shallowClone = obj => Object.assign({}, obj);。

 1const deepClone = obj => { 2  if (obj === null) return null; 3  let clone = Object.assign({}, obj); 4  Object.keys(clone).forEach( 5    key => (clone[key] = typeof obj[key] === 'object' ? deepClone(obj[key]) : obj[key]) 6  ); 7  return Array.isArray(obj) && obj.length 8    ? (clone.length = obj.length) && Array.from(clone) 9    : Array.isArray(obj)10      ? Array.from(obj)11      : clone;12};

原文链接

https://www.30secondsofcode.org/blog/s/javascript-shallow-deep-clone

  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net