美文网首页
浅/深拷贝

浅/深拷贝

作者: my木子 | 来源:发表于2021-04-27 21:38 被阅读0次

浅拷贝

  • 只复制最外部一层,基础数据类型的值和引用数据类型的地址
        let obj1 = {
            a: 1,
            b: {
                n: 2
            }
        };

        // 浅拷贝 1
        function shallowClone(obj) {
            const newObj = {};
            for (let i in obj) {
                if (Object.hasOwnProperty.call(obj, i)) {
                    newObj[i] = obj1[i]
                }
            }
            return newObj;
        }
        let obj2 = shallowClone(obj1);

        // 浅拷贝 2 ES6 扩展运算符
        // let obj2 = {
        //     ...obj1
        // };

        // 浅拷贝 3 Object.assign()
        // let obj2 = Object.assign(obj1);

        // obj2.a = 1111;     // 因为是基本数据类型,存值,所以互不影响
        // obj2.b.n = 2222;   // 因为是应用数据类型,指向同一个地址,所以 obj2.b 的值修改时会影响 obj1.b

        console.log(obj1, obj2);
        console.log(obj1.b === obj2.b); // true

深拷贝

  • 将数据中所有的数据拷贝下来,对拷贝之后的数据进行修改不会影响到原数据。

  • JSON.parse(JSON.stringify(obj)),一般情况下推荐,其中 obj 只能是 NumberStringBooleanArray扁平对象,即那些能够被 JSON 直接表示的数据结构。

        let obj1 = {
            a: 1,
            b: [1, 2],
            c: {
                x: 3
            },
            d: /^\d+$/,
            e: null,
            f: undefined,
            g: function () {}
        };

        // 判断变量的类型
        function getType(obj) {
            var type = Object.prototype.toString.call(obj);
            var map = {
                '[object Boolean]': 'boolean',
                '[object Number]': 'number',
                '[object String]': 'string',
                '[object Undefined]': 'undefined',
                '[object Null]': 'null',
                '[object Object]': 'object',
                '[object Function]': 'function',
                '[object Array]': 'array',
                '[object Date]': 'date',
                '[object RegExp]': 'regExp'
            }
            if (obj instanceof Element) { //判断是否是dom元素,如div等
                return "element";
            }
            return map[type];
        }

        //深拷贝函数
        function deepClone(obj) {
            let cloneObj;
            let type  = getType(obj);
            console.log(obj,type)
            if (type === 'array') {
                cloneObj = [];
                for (let i = 0; i < obj.length; i++) {
                    cloneObj.push(deepClone(obj[i]));
                }
            } else if (type === 'object') {
                cloneObj = {};
                for (let i in obj) {
                    cloneObj[i] = deepClone(obj[i]);
                }
            } else {
                return obj;
            }
            return cloneObj;
        }

        let obj3 = deepClone(obj1);
        console.log(obj1, obj3);
        console.log(obj1.f === obj3.f);

lodash 深拷贝

掘金

相关文章

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

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

  • js浅拷贝深拷贝

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

  • JS中的深拷贝与浅拷贝

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

  • iOS - copy 与 mutableCopy

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

  • iOS面试题-第二页

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

  • iOS--拷贝相关题

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

  • 2018-10-10函数基础

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

  • 2018-10-10day9函数基础

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

  • OC深拷贝PK浅拷贝,欢迎来战!

    OC深拷贝PK浅拷贝,欢迎来战! OC深拷贝PK浅拷贝,欢迎来战!

  • 浅拷贝和深拷贝

    本文参考:JavaScript中的浅拷贝和深拷贝js 深拷贝 vs 浅拷贝深入剖析 JavaScript 的深复制...

网友评论

      本文标题:浅/深拷贝

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