美文网首页
深拷贝、浅拷贝

深拷贝、浅拷贝

作者: 每天进步一点点5454 | 来源:发表于2020-05-25 14:43 被阅读0次

首先我们先学习一下深拷贝和浅拷贝的数据类型都有哪些?

  • 基本数据类型:检测类型typeof()

Undefined、Null、Boolean、Number、String、Symbol (new in ES 6) !

  • 引用类型:instanceof

除过上面的 6 种基本数据类型外,剩下的就是引用类型了,统称为Object 类型。细分的话,有:Object 类型、Array 类型、Date 类型、RegExp 类型、Function 类型等

深拷贝:就是在原有的数据上在复制一份,开辟一个新的空间
浅拷贝:就是复制了一份,没有新开辟

深拷贝、浅拷贝

前端数据交互赋值的时候很容易遇到深拷贝浅拷贝的问题,就会导致数据的耦合,今天来用一组代码来讲解一下

<script>
    var json = { a: 123, b: '456' };
    console.log(json)
    var json2 = json
    json2.a=222
    console.log(json2)
</script>

打印出来的结果应该如下:


image.png

虽然表面看我们的数据没有任何变化,但是当我们打开数据的时候就会发现如下结果:


image.png

我们json中的数据被影响了,
解决方案如下:

<script>
    var json = { a: 123, b: '456' };
    console.log(json)
    var json2 = JSON.parse(JSON.stringify(json));
    json2.a=222
    console.log(json2)
</script>

我们将数组中的值先JSON.stringify()转义一下,之后使用JSON.parse赋值给json2,我们可以理解为一个新的数组,在json2中的值进行修改就不会影响到原json中的值,这样就解决了深拷贝的问题


image.png

JQ中也提供了一个深拷贝方法,代码如下:

<script>
    var json = { a: 123, b: '456' };
    console.log(json)
    var json2 = $.extend(true, {}, json);
    json2.a=222
    console.log(json2)
</script>
image.png

相关文章

  • iOS深拷贝(MutableCopy)与浅拷贝(Copy)的区别

    深拷贝和浅拷贝的概念 iOS中有深拷贝和浅拷贝的概念,那么何为深拷贝何为浅拷贝呢?浅拷贝:浅拷贝并不拷贝对象本身,...

  • iOS - copy 与 mutableCopy

    一说到拷贝,就不得不提浅拷贝和深拷贝。 何谓浅拷贝?何谓深拷贝? 往简单的说: 浅拷贝:拷贝地址。 深拷贝:拷贝内...

  • iOS面试题-第二页

    11.深拷贝和浅拷贝的理解. 深拷贝;拷贝的内容. 浅拷贝:拷贝的指针. 深拷贝如: NSMutableDicti...

  • js浅拷贝深拷贝

    js浅拷贝,深拷贝的简单实现 基础数据 浅拷贝 深拷贝

  • JS中的深拷贝与浅拷贝

    知乎:js中的深拷贝和浅拷贝? 掘金: js 深拷贝 vs 浅拷贝 前言 首先深拷贝与浅拷贝只针对 Object,...

  • iOS--拷贝相关题

    1、什么是深拷贝什么是浅拷贝?浅拷贝和深拷贝的区别 * 浅拷贝(shallow copy):指针拷贝,对于被拷贝对...

  • 2018-10-10day9函数基础

    1.浅拷贝、深拷贝 copy.copy(对象):浅拷贝copy.deepcopy(对象):深拷贝""" """拷贝...

  • 2018-10-10函数基础

    深拷贝和浅拷贝 深拷贝 copy.deepcopy(对象)浅拷贝 copy.copy(对象)深拷贝: 将对象对应的...

  • 深拷贝和浅拷贝

    1.深拷贝:地址的拷贝 2.浅拷贝:是值得拷贝 深拷贝和浅拷贝的区别 A拷贝B B变A变是浅拷贝 A拷贝B B变A...

  • 对象深拷贝和浅拷贝

    浅拷贝 深拷贝 深拷贝的递归方法 深拷贝的JSON方法

网友评论

      本文标题:深拷贝、浅拷贝

      本文链接:https://www.haomeiwen.com/subject/lgdyahtx.html