克隆javascript纯对象

克隆javascript纯对象

月光魔力鸭

2018-09-11 08:39 阅读 759 喜欢 0 对象克隆 深度克隆

背景

在使用echarts 来做统计报表的时候,由于数量较多,准备将同类型的相同属性抽取出来,然后用来做默认属性的。结果发现一个问题。

使用Object.assign只能复制第一层属性,对于深层的无法复制。

举例:

var object1 = {
  title : {
    name : 'default',
    style : '#49e'
  }
};
var option = {
  title : {
    name : 'test',
    size : 22
  }
};
var newObject = Object.assign(object1,option);
//我们希望的结果是
{
  title : {
    name : 'test',
    style : '#49e',
    size : 22
  }
}
//而实际的结果却实
{
  title : {
    name : 'test',
    size : 22
  }
}
//只能覆盖第一层属性。

自己动手实现clone

function clone(){
        var args = slice.call(arguments);
        if(args.length == 0){
            return {};
        }else if(args.length == 1){
            //创造一个新的返回
            var source = args[0];
            if(typeof source != 'object'){
                return source;
            }else{
                var newTarget = {};
                for(var k in target){
                    newTarget[k] = target[k];
                }		
                return newTarget;
            }
        }else{
            //多个参数
            var target = args[0];
            var left = args.splice(1);
            if(typeof target == 'object'){
                var newTarget = {};
                //先复制
                for(var k in target){
                    newTarget[k] = target[k];
                }
                for(var i=0;i<left.length;i++){
                    var source = left[i];
                    for(var k in source){
                        newTarget[k] = clone(newTarget[k],source[k]);
                    }
                }
                return newTarget;
            }else{
                return left[0];
            }
        }
}

支持以下几种形式

var object = {
  title : {
    name : 'test'
  }
};
var object1 = clone(object);
//克隆出一个新的对象

var object2 = {
  title : {
    style : '#49e'
  }
};
var object3 = clone(object,object2);
//覆盖属性

var object4 = {
  title : {
    style : '#f60',
    size : 22
  }
};
var object5 = clone(object,object2,object4);
//多参数,最终是从后向前覆盖

可能存在的问题

如果对象特别大...有可能会回调溢出吧 。毕竟这是递归处理的。(没有进行测试过呢)

转载请注明出处: https://chrunlee.cn/article/javascript-clone-object.html


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
对于web开发过程中的JS对象 Array ,我们真的充分使用了么?是不是理解了Array的全部?能够在合适的地点调用合适的函数,使用合适的属性?
有时候浏览网页经常会看见一些页面出现一些打字的效果,那么是怎么实现的呢?
突然来了一个调研任务,想要实现一个类似3D虚拟展厅类似的需求,主要就是放一些学生的作品,然后预览啥的,效果还是要全景的效果。 经过一番调查,最终锁定了以前从未接触过的krpano。
web开发中,前台有时候会需要一个随机数或序列,通常来说,这个随机数可能只在当前页面中使用,并不需要太过严格,大体上重复率低即可。
当一些业务必须通过横屏来实现,但是又没有原生来做,只能通过h5的时候怎么办?
在我们通过canvs画图的时候经常会用到圆,且需要计算出圆上某点的坐标,由于我数学没学好,总是记不得怎么获取,这里记录下,加深记忆
本文概括了递归、闭包、原型、继承,理清这些基本的概念,有助于你接纳更多的东西,我们会在下一个章节对函数进行更深入的讨论。
我们有时候会拿textarea来做编辑器,但是常用编辑器都是支持tab缩进的,这里对textarea监听下事件处理下即可实现。