为了账号安全,请及时绑定邮箱和手机立即绑定

js如何进行多层级的深度拷贝?

js如何进行多层级的深度拷贝?

郎朗坤 2019-02-19 13:15:49
需求是这样的,有一个对象avar a = {          a: '1',          b: '2',          d: {               q: {                    r: '3'                  },                w: {                     r: '4'                  }             }         }然后有一个数组,数组每个子项是在对象a的基础上,多一个a.d的每一个子项,结果这样的b = [{       a: '1',       b: '2',       c: {            d: {                 r: '3'               }          }},      {        a: '1',        b: '2',        c: {             d: {                  r: '4'                }           }       }]这个应该是深度拷贝的问题吧,要怎么实现呢,试了JSON.parse(JSON.stringify())的方法发现行不通,r的值都会是4,求大神帮忙解答下
查看完整描述

1 回答

?
喵喵时光机

TA贡献1846条经验 获得超7个赞

自己用的, 用到underscore的地方可以自己改一下

    var COMMON = {};


    COMMON.merge = function (target, source, source2) {

        if (source && typeof source === 'object') {

            if (!target || typeof target !== 'object') {

                target = _.isArray(source) ? [] : {};

            }

            for (var key in source) {

                if (source.hasOwnProperty(key)) {

                    if (source[key] && typeof source[key] === 'object') {

                        if (!target[key] || typeof target[key] !== 'object') {

                            target[key] = _.isArray(source[key]) ? [] : {};

                        }

                        COMMON.merge(target[key], source[key]);

                    } else {

                        target[key] = source[key];

                    }

                }

            }

        }

        return (source2 && typeof source2 === 'object') ? COMMON.merge(target, source2) : target;

    };


    COMMON.clone = function (obj) {

        if (obj && typeof obj === 'object') {

            if (_.isArray(obj)) {

                return _.map(obj, function (item) {

                    return COMMON.clone(item);

                });

            } else {

                return COMMON.merge({}, obj);

            }

        }

        return obj;

    };


查看完整回答
反对 回复 2019-02-23
  • 1 回答
  • 0 关注
  • 443 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号