我是靠谱客的博主 疯狂高山,最近开发中收集的这篇文章主要介绍es6解构是深拷贝吗,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

本教程操作环境:windows10系统、ECMAScript 6.0版、Dell G3电脑。

es6解构是深拷贝吗

关于ES6中的解构赋值的知识点,想必大家都不陌生。所谓解构赋值就是利用一种模式来快速从目标结构中取出数据的方案,例如:
在这里插入图片描述
通过解构,我们很轻松的就从数组和对象中取出了我们想要的数据。但是,可能大家会问,这与深拷贝与浅拷贝又有什么关系呢?

咱们,先回顾一下关于深拷贝和浅拷贝,

所谓的浅拷贝和深拷贝:浅拷贝是在在拷贝过程中,遍历时那部分为对象/数组类型指向原来的地址,而深拷贝,则是完全开辟新的内存地址。也就是说,

  • 深拷贝:修改新变量的值不会影响原有变量的值。默认情况下基本数据类型(number,string,null,undefined,boolean)都是深拷贝。
  • 浅拷贝:修改新变量的值会影响原有的变量的值。默认情况下引用类型(object)都是浅拷贝。

那么,在解构中,究竟是深拷贝还是浅拷贝呢?

在这里插入图片描述
在上述代码中,我们分别对数组和对象进行解构,然后又修改了解构之后的变量的值,然后分别打印变量和原数组和对象,结果如下:

在这里插入图片描述
我们发现,原数组和对象的数据并没有改变,是不是就说明解构赋值就是深拷贝了呢??

我们把例子稍微修改一下,代码如下:

在这里插入图片描述
我们为对象新增了一个data属性,data的数据为一个数组,然后解构之后,我们修改了data的数据,结果如下:

在这里插入图片描述
我们发现,解构出来的变量data的改变引起了原来数据的改变,也就是所,解构赋值其实依然是浅拷贝。

总结一下:

【相关推荐:javascript视频教程、web前端】

以上就是es6解构是深拷贝吗的详细内容,更多请关注靠谱客其它相关文章!

最后

以上就是疯狂高山为你收集整理的es6解构是深拷贝吗的全部内容,希望文章能够帮你解决es6解构是深拷贝吗所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(72)

评论列表共有 0 条评论

立即
投稿
返回
顶部