js中浅拷贝和深拷贝的区别

这篇具有很好参考价值的文章主要介绍了js中浅拷贝和深拷贝的区别。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在JavaScript中,浅拷贝(Shallow Copy)和深拷贝(Deep Copy)是两种不同的复制对象的方法,它们之间存在一些重要的区别。

  1. 浅拷贝(Shallow Copy):
    浅拷贝只复制对象的顶层属性,如果属性是对象或数组,则复制的是引用,而不是实际的对象。这意味着,如果更改了复制后的对象中的嵌套对象或数组,原始对象的相应属性也会被更改。这是因为浅拷贝只是简单地复制了外层的引用,而没有复制内部的对象或数组。
  2. 深拷贝(Deep Copy):
    深拷贝则完全不同,它会递归地复制对象的所有层级属性,包括对象和数组。这意味着,如果复制后的对象中的嵌套对象或数组被更改,原始对象的相应属性不会受到影响。深拷贝创建了一个全新的、独立的副本,包括内部的对象和数组。

以下是一个使用JavaScript实现浅拷贝和深拷贝的示例代码:

javascript// 定义一个复杂的数据结构
let data = {
name: 'John',
age: 25,
address: {
street: '123 Main St',
city: 'Anytown',
state: 'CA',
zip: '12345'
},
phoneNumbers: ['123-456-7890', '987-654-3210']
};

// 浅拷贝示例
let shallowCopy = Object.assign({}, data);
console.log('浅拷贝结果:', shallowCopy);

// 修改原始数据中的嵌套对象或数组
data.address.city = 'New York';
data.phoneNumbers[1] = '555-123-4567';
console.log('原始数据:', data);
console.log('浅拷贝后的数据:', shallowCopy); // 浅拷贝后的数据会受到原始数据的影响

// 深拷贝示例(使用JSON.stringify和JSON.parse方法)
let deepCopy = JSON.parse(JSON.stringify(data));
console.log('深拷贝结果:', deepCopy);

// 修改复制后的数据中的嵌套对象或数组
deepCopy.address.city = 'London';
deepCopy.phoneNumbers[1] = '098-765-4321';
console.log('深拷贝后的数据:', deepCopy); // 深拷贝后的数据不会影响原始数据

在这个示例中,我们首先定义了一个复杂的数据结构data,它包含了一个对象、一个数组以及一个嵌套的对象和数组。然后,我们使用Object.assign()方法实现了浅拷贝,并使用JSON.stringify()JSON.parse()方法实现了深拷贝。通过比较原始数据和复制后的数据,我们可以看到浅拷贝和深拷贝之间的区别。在浅拷贝中,如果更改了复制后的数据中的嵌套对象或数组,原始数据也会受到影响;而在深拷贝中,更改复制后的数据中的嵌套对象或数组不会影响原始数据。

总结来说,浅拷贝只复制对象的顶层属性,复制的是引用而非实际的对象;而深拷贝会递归地复制对象的所有层级属性,创建一个全新的、独立的副本。在处理复杂的数据结构时,深拷贝更为安全和可靠。文章来源地址https://www.toymoban.com/news/detail-808556.html

到了这里,关于js中浅拷贝和深拷贝的区别的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 什么是浅拷贝和深拷贝

    javascript 中有不同的方法来复制对象,那么我们怎样才能正确地复制一个对象呢? 本文来介绍一下浅拷贝和深拷贝。 一、什么是浅拷贝(Shallow Copy) 浅拷贝是创建一个新对象,新对象有着原始对象属性值的一份精确拷贝。如果属性是基本类型,拷贝的就是基本类型的值,如果属性

    2024年02月08日
    浏览(31)
  • 一文彻底理解python浅拷贝和深拷贝

    万物皆对象:在学习python的深浅拷贝之前我们必须要知道一个事情,就是python对象的引用,在python里面, 万物皆对象,万物皆对象,万物皆对象 ,不管什么数据类型都是对象。我们定义一个变量并给这个变量赋值的时候赋的并不是这个对象值,而是这个对象引用,并不是一

    2024年02月07日
    浏览(33)
  • JavaScript深拷贝(js深拷贝,JavaScript递归函数,实现深拷贝)

    简述:JavaScript的深拷贝和浅拷贝大家都比较熟悉,今天来分享下深拷贝,就是使用该函数时,会复制拷贝一份该数据,修改该数据属性,不会改变原有数据,就是把复制的对象所引用的对象全都复制了一遍,具体实现如下; 1、定义拷贝对象; 2、定义递归函数deepClone(),实现

    2024年02月15日
    浏览(49)
  • 理解C#中对象的浅拷贝和深拷贝

    本文章主要介绍C#中对象的拷贝,其中包括浅拷贝和深拷贝,以及浅拷贝和深拷贝的实现方式,不同的实现方式之间的性能对比。   浅拷贝是指将对象中的数值类型的字段拷贝到新的对象中,而对象中的引用型字段则指复制它的一个引用到目标对象。如果改变目标对象中引用

    2024年02月08日
    浏览(29)
  • Python - 拷贝 - 浅拷贝(Shallow Copy)和深拷贝(Deep Copy)

    假设我以这样的方式创建一个 3 x 5 的二维数组: 然后我修改 a [ 2 ] [ 3 ] a[2][3] a [ 2 ] [ 3 ] 的值为 1 1 1 : 结果会发现数组 a a a 中第二维坐标为 3 3 3 的数全部被修改为了 1 1 1 ,而没有发生“第一维坐标为 2 2 2 的数全部被改成了 1 1 1 ” 这就涉及到了Python中的拷贝机制。 Python中

    2023年04月08日
    浏览(27)
  • java八股文面试[java基础]——浅拷贝和深拷贝

      自验证:创建Class Student两个类, Student中含有Class对象 测试代码: 输出: 可以看到不同的Student对象,但是有相同的Class对象 修改Student clone方法: 可以看到不同的class对象,不同的值: 知识来源: 【23版面试突击】什么是浅拷贝和深拷贝_哔哩哔哩_bilibili 强引用、弱引用介

    2024年02月11日
    浏览(29)
  • BCSP-玄子前端开发之JavaScript+jQuery入门CH07_ECMAScript 6基础

    4.7.1 ECMAScript 6 简介 ECMAScript 6.0(简称 ES6) 是JavaScript语言的下一代标准 正式发布于2015年6月 目标 使JavaScript语言可以用来编写复杂的大型应用程序,成为企业级开发语言 版本升级 ECMAScript 2015 ECMAScript 2016 ECMAScript 2017 ECMAScript和JavaScript 的关系 前者是后者的规格,后者是前者的

    2023年04月27日
    浏览(44)
  • JS中深拷贝浅拷贝的区别

    深浅拷贝在MDN官方中的表述是这样的: 对象的 深拷贝 是指其属性与其拷贝的源对象的属性不共享相同的引用(指向相同的底层值)的副本。因此,当你更改源或副本时,可以确保不会导致其他对象也发生更改;也就是说,你不会无意中对源或副本造成意料之外的更改。这种

    2024年02月06日
    浏览(23)
  • Python入门【变量的作用域(全局变量和局部变量)、参数的传递、浅拷贝和深拷贝、参数的几种类型 】(十一)

     👏作者简介:大家好,我是爱敲代码的小王,CSDN博客博主,Python小白 📕系列专栏:python入门到实战、Python爬虫开发、Python办公自动化、Python数据分析、Python前后端开发 📧如果文章知识点有错误的地方,请指正!和大家一起学习,一起进步👀 🔥如果感觉博主的文章还不错

    2024年02月15日
    浏览(40)
  • 3分钟搞懂:JavaScript 和 ECMAScript

    ECMAScript 是 JavaScript 语言的 国际标准 ,JavaScript 是 ECMAScript 的 一种实现 (Adobe ActionScript 和 JScript 同样实现了 ECMAScript)。 ECMAScript 是欧洲计算机制造商协会 ECMA(European Computer Manufacturers Association)发布的浏览器脚本语言标准。它是 262 号标准文件,又叫 ECMA-262。 ECMAScript 定义

    2023年04月22日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包