浅/深拷贝

2021-04-27  本文已影响0人  my木子

浅拷贝

        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

深拷贝

        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 深拷贝

掘金

上一篇 下一篇

猜你喜欢

热点阅读