首页 > 编程语言 > 详细

JavaScript 实现深度拷贝

时间:2019-03-31 16:13:18      阅读:200      评论:0      收藏:0      [点我收藏+]
var obj = {
            name: "abc",
            age: 123,
            card: [‘visa‘, ‘master‘],
            wife: {
                name: ‘bcd‘,
                son: {
                    name: ‘aaa‘
                }
            }
        }
        var obj1 = {

        }
        //深度拷贝
        function deepClone(origin, target) {
            var target = target || {},
                toStr = Object.prototype.toString,
                arrStr = "[object Array]";
            for (var prop in origin) {
                if (origin.hasOwnProperty(prop)) {
                    if (origin[prop] !== "null" && typeof (origin[prop]) == ‘object‘) {
                        // if (toStr.call(origin[prop]) == arrStr) {
                        //     target[prop] = [];
                        // } else {
                        //     target[prop] = {};
                        // }
                        target[prop] = toStr.call(origin[prop]) == arrStr ? [] : {};
                        deepClone(origin[prop], target[prop]);
                    } else {
                        target[prop] = origin[prop];
                    }
                }
            }
            return target;
        }
        deepClone(obj, obj1);

 

JavaScript 实现深度拷贝

原文:https://www.cnblogs.com/FashionDoo/p/10631693.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!