js 浅拷贝有大用

Posted 一名前端开发者

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js 浅拷贝有大用相关的知识,希望对你有一定的参考价值。

 

如题

 像浅拷贝、深拷贝这类的知识点我们应该都明白是怎么回事,大部分都是在面试的时候会被问到。大多让你实现一个深拷贝。现实中我们都用比较暴力直接的手段 JSON stringify.

一句话就搞定,管他性能不性能的。不过写了这么多代码,深拷贝用的确实不怎么多。反而浅拷贝用的比较多,尤其是 Object.assign 被大量使用。

当然我并不是想分享他的实现远离。而是想说下我突然感觉到浅拷贝有个亮点。

 不知道大家有没有听过,共享结构这个词。

意思是一个新的对象的结构和旧对象的结构一至,是从原始对象直接复制过来的。当然不是说直接负值的,而是使用上面的Object.assign 实现的。

其结果是产生一个新对象。

 

浅拷贝的作用在于对于简单类型可以直接复制其值,对于复杂类型 复制的是一个对象具柄,也就是两个对象指向的是同一块内存区域。

 

好了,通过这种方式产生的两对象,有什么用呢?  我们可以很方便的检测到 新旧两个对象的差异,也就是哪个key的值不同,可以通过一层便利就可以对比出来。

这个时候可以脑补下画面,声明一个对象 aaa,里面包含 两个key ,一个是title 表示标题,一个是list 表示列表 一个数组 【1,2,3】,然后使用Object.assign,进行浅拷贝一个新对象。

新对象和原对象做比较 即便是两个对象的内容没有做任何改变,但是两对象是完全不等的。因为是生成了一个新对象。但是当我们比较下两个对象的list的时候,是完全相等的。

 

第二部。再使用 Object.assign 对愿对象进行生成一个新对象,这个时候 我们增加第三个参数,是一个对象 ,key 是list  【1,2】。

好,得到结果  比较两个对象的list,是完全不等的。因为指向了不同的饮用地址。不知道我们上面这么描述是否清洗,大家脑补的怎样了。

 

脑补成功了吗,是不是觉得这个特性很6,那么我们自己就可以写一个获取新旧对象的差异方法了。返回差异的key的列表。是吧?

另外说下 脑补,

学技术脑补还是很重要的。没有电脑的时候就要靠脑子进行预演。


 

应用场景

那这个特性的应用场景有哪些呢?这个我也说不好,大家可以自己想下自己曾做过的项目。  我这里能想到的场景有2个

1. 比如我们要一个小程序的查询列表页面,这个页面包含很多的条件。有的在当前页面,有的需要跳转页面设置条件,这个时候就需要在回到页面后进行判断条件是否有变化,有变化就重新请求数据渲染页面。

2. 我想到了redux里的reducer这个纯函数,reducer获得state和action两个对象,不管state有无变化都会返回一个新对象。这里使用的就是这个特性。

 

共享结构实现的方法

 1.上面说的 object.assgin

2. 扩展运算符 

3. 如果大家知道的话可以告诉哈

 

总结下:

本节就是介绍了下浅拷贝的妙用,以及提到的一个名字 “共享结构”,以及他的使用场景。当然这种主要是对简单对象,层级也就2层把。层级太多的话复杂度就增加了。具体是否能适用就看具体的场景了。

 

家里电脑卡,错别字较多,还有代码回头补上。

 

以上也可以在 喜马拉雅 上 订阅 “大前端开发解惑” 进行收听

 

以上是关于js 浅拷贝有大用的主要内容,如果未能解决你的问题,请参考以下文章

深拷贝和浅拷贝怎样理解(通俗具体点儿)

js 对象的浅拷贝和深拷贝

js对象深拷贝浅拷贝

前端开发:JS中深拷贝和浅拷贝的区别

JS的深拷贝和浅拷贝

老生常谈之js深拷贝与浅拷贝