js对象深拷贝

Posted 黎明之光123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js对象深拷贝相关的知识,希望对你有一定的参考价值。

/**
*对象深拷贝2018-3-2
*使用方法deepAssign(obj1,obj2...)
**/        
		
		
		
		//测试
		//var china = {
        //    nation : ‘中国‘,
        //    birthplaces:[‘北京‘,‘上海‘,‘广州‘],
        //    skincolr :{aa:111,bb:{qq:{hahha:{kkkk:"哈哈哈"}}}},
        //    friends:[‘sk‘,‘ls‘]
       // }
       // var result = {name:‘result‘, skincolr :{aa:111,bb:{qq:{hahha:{kkkk:"可以啦啦啦啦"}}}}}

        //深复制,要想达到深复制就需要用递归
        function isObj(x){
            var type = typeof x;
            return x !== null && (type === ‘object‘ || type === ‘function‘);
        }

        var hasOwnProperty = Object.prototype.hasOwnProperty;
        var propIsEnumerable = Object.prototype.propertyIsEnumerable;

        function toObject(val) {
            if (val === null || val === undefined) {
                throw new TypeError(‘Cannot convert undefined or null to object‘);
            }

            return Object(val);
        }

        function assignKey(to, from, key) {
            var val = from[key];

            if (val === undefined || val === null) {
                return;
            }

            if (hasOwnProperty.call(to, key)) {
                if (to[key] === undefined || to[key] === null) {
                    throw new TypeError(‘Cannot convert undefined or null to object (‘ + key + ‘)‘);
                }
            }

            if (!hasOwnProperty.call(to, key) || !isObj(val)) {
                to[key] = val;
            } else {
                to[key] = assign(Object(to[key]), from[key]);
            }
        }

        function assign(to, from) {
            if (to === from) {
                return to;
            }

            from = Object(from);

            for (var key in from) {
                if (hasOwnProperty.call(from, key)) {
                    assignKey(to, from, key);
                }
            }

            if (Object.getOwnPropertySymbols) {
                var symbols = Object.getOwnPropertySymbols(from);

                for (var i = 0; i < symbols.length; i++) {
                    if (propIsEnumerable.call(from, symbols[i])) {
                        assignKey(to, from, symbols[i]);
                    }
                }
            }

            return to;
        }

        function deepAssign(target) {
            target = toObject(target);

            for (var s = 1; s < arguments.length; s++) {
                assign(target, arguments[s]);
            }

            return target;
        };
       // deepAssign(china,result)
		//console.log(china)

  

以上是关于js对象深拷贝的主要内容,如果未能解决你的问题,请参考以下文章

js对象深拷贝

JS中如何进行对象的深拷贝

JS深拷贝数组和对象

js的浅拷贝和深拷贝

JS基础 - 手写深拷贝

js 对象的浅拷贝和深拷贝