如题

像浅拷贝、深拷贝这类的知识点我们应该都明白是怎么回事,大部分都是在面试的时候会被问到。大多让你实现一个深拷贝。现实中我们都用比较暴力直接的手段 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 浅拷贝有大用的更多相关文章

  1. 关于js浅拷贝与深拷贝的理解

    前端开发中,一般情况下,很少会去在意深拷贝与浅拷贝的关系. 大家知道,js变量有2种数据类型:基本类型和引用类型.基本类型的拷贝是将整个值完全拷贝一份的,也就是深拷贝.就是开辟了新的堆内存.所以基本类 ...

  2. 关于JS浅拷贝和深拷贝

    在 JS 中有一些基本类型像是Number.String.Boolean,而对象就是像这样的东西{ name: 'Larry', skill: 'Node.js' },对象跟基本类型最大的不同就在于他 ...

  3. JS - 浅拷贝与深拷贝的理解以及简单实现方法

    前几天撸项目代码时, 由一个技术点间接牵扯出了这东西. 所以就来总结一下. 深拷贝 拷贝对象每个层级的属性. 作用的对象是 js中引用类型的对象,基本类型没有涉及. 本质上将引用类型的对象在堆上重新开 ...

  4. 理解js浅拷贝和深拷贝

    理解深拷贝和浅拷贝之前先了解下js中的基本类型和引用类型 1.基本类型: 在js中,数据的基本类型undefined,null,string,number,boolean,在变量中赋的实际值,基本类型 ...

  5. js浅拷贝(地址引用)和深拷贝(克隆)

    浅拷贝和深拷贝相对于引用类型而言的. js有两大类型值类型(基本数据类型)和引用类型(object,function,array): 值类型保存在栈上,引用类型保存在堆上. 浅拷贝只是单纯的拷贝对象的 ...

  6. js 浅拷贝和深拷贝

    传值与传址 了解了基本数据类型与引用类型的区别之后,我们就应该能明白传值与传址的区别了.在我们进行赋值操作的时候,基本数据类型的赋值(=)是在内存中新开辟一段栈内存,然后再把再将值赋值到新的栈中.例如 ...

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

    前言 经常会在一些网站或博客看到"深克隆","浅克隆"这两个名词,其实这个很好理解,今天我们就在这里分析一下js深拷贝和浅拷贝. 浅拷贝 我们先以一个例子来说明 ...

  8. 开发过程中遇到的js知识点总结,面试题等,持续更新

     1.Object.freeze() 方法用于冻结一个对象,即将对象设置为不可扩展.将对象的所有自有的属性和方法(包括Symbol值的属性和方法)配置为不可配置,不可写. Object.freeze( ...

  9. 深入理解jQuery框架-框架结构

    这是本人结合资料视频总结出来的jQuery大体框架结构,如果大家都熟悉了之后,相信你们也会写出看似高档的js框架: jquery框架的总体结构 (function(w, undefined){ //定 ...

随机推荐

  1. sqoop导数

    #!/bin/bash source ExitCodeCheck.shopts=$@getparam(){ echo $opts|xargs -n1|cut -b 2-|awk -v arg=$1 - ...

  2. 浏览器在初始化JS 环境时都发生了些什么

    原文:https://segmentfault.com/a/1190000005754797 1.用 C/C++ 构造内部数据结构创建一个 OP 即(Object.prototype)以及初始化其内部 ...

  3. Python爬虫抓取某音乐网站MP3(下载歌曲、存入Sqlite)

    最近右胳膊受伤,打了石膏在家休息.为了实现之前的想法,就用左手打字.写代码,查资料完成了这个资源小爬虫.网页爬虫, 最主要的是协议分析(必须要弄清楚自己的目的),另外就是要考虑对爬取的数据归类,存储. ...

  4. An internal error occurred during: "Initializing Java Tooling". Eclipse启动发生的错误

    An internal error occurred during: “Initializing Java Tooling” 错误经常是莫名其妙的出现这种总错误,解决办法: 1.eclipse -&g ...

  5. 【ExtJS】FormPanel 布局(一)

    准备工作,布置一个最简单的Form,共5个组件,都为textfield. Ext.onReady(function(){ Ext.create('Ext.form.Panel', { width: 5 ...

  6. unity接入安卓sdk (unity调用安卓工程)

    1.安装jdk 并且配置环境,这个网上资料很多,这里不说了 2.安卓开发软件eclipse集成环境版 下载地址 http://tools.android-studio.org/index.php/ad ...

  7. 【.Net】 C#参数数组与函数重载

    static int ParamsFunc(int i, string s) { return i; } static int ParamsFunc(int i, string s, params i ...

  8. python3根据地址批量获取百度地图经纬度

    python3代码如下: import requests import time def get_mercator(addr): url= 'http://api.map.baidu.com/geoc ...

  9. Golang教程:switch 语句

    switch 是一个条件语句,用于将一个表达式的求值结果与可能的值的列表进行匹配,并根据匹配结果执行相应的代码.可以认为 switch 语句是编写多个 if-else 子句的替代方式. 举例是说明问题 ...

  10. 【eclipse安装黑色主题】

    eclipse Luna Service Release 2 (4.4.2)版本的自带了黑色的主题,切换下即可: 切换主题以后还需要修改下字体的主题: http://www.eclipsecolort ...