码迷,mamicode.com
首页 > 其他好文 > 详细

深度克隆

时间:2015-01-31 00:19:14      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:

如何使用原生 Javascript 代码深度克隆一个对象(注意区分对象类型)

对于深度克隆,我的理解是:在克隆或扩展一个对象时,当该对象是一个包括子对象的对象,也会遍历该子对象的属性并进行复制拷贝。所以深度克隆适用于对象的属性也是对象的情况。

贴出js代码:

技术分享
   /**
    * 深度扩展对象--适用于对象的属性也是对象的情况
    * @param {Object}
    * @return {Object}
    */
    var deepextend = function (destination, source) {
        for (var property in source) {
            var copy = source[property]; // 获取source属性值

            if (destination === copy) {
                continue;
            }

            // 如果copy是一个对象,则递归调用(并传入copy参数),直到copy不是一个对象为止
            if (typeof copy === ‘object‘) {//$.isObj(copy)
                destination[property] = arguments.callee(destination[property] || {}, copy); //递归调用
            // 否则直接把copy赋值给destination对象的属性(此时与$.extend方法等价)
            } else {
                destination[property] = copy;
            }
        }
        return destination;
    };

深度克隆

标签:

原文地址:http://www.cnblogs.com/zhangwenkan/p/4263346.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!