克隆javascript纯对象

克隆javascript纯对象

月光魔力鸭

2018-09-11 08:39 阅读 662 喜欢 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开发过程中,现在JSON 已经到了俯拾皆是的地步了,操作JSON对于JS来说非常简单,那么我们对于JSON的转化是如何应对的呢?
java 对象中有很多引用,甚至会出现循环引用,比如 user 对象中有 school 对象,school 对象中又有 user 对象,这样在对 user 对象序列化的时候,就会出现死循环,导致内存溢出。通过一定的方式,将每个对象增加ID 和 REF 引用标识最终可以解决这个问题
错误:The operation is insecure . 在使用canvas的 toDataUrl的时候报错,看了很多资料,基本上都说是设置跨域,但是我一直都有的啊。其实,只是顺序错了,setAttribute('crossOrigin','Anonymous') 要在设置 src之前设置。
先记录下,不定哪天就查了..防止找不到或不全
jsQR 是一款纯粹的由javascript实现的二维码识别库,可以在浏览器端使用,也可以在后端node.js环境使用。我之前使用过其他的识别库,例如:qrcode-reader 或其他,在使用上都比较麻烦,而且识别率并不高。jsQR是后来发现的,感觉(没有实际对比验证)jsQR识别率要更高些,使用起来也更简单,不需要安装其他依赖软件。
在我们web开发过程中经常会碰到针对table的一些dom操作,这里整理一下关于这方面的知识点。当然我们可以通过jquery这样的插件来处理,或许会更简单一些,不过现在简单说下原生JS是如何操作的
整理下关于axios的使用,一些常用的调用、处理以及其他。
如何通过js调用本地摄像头呢?获取后如何对视频进行截图呢?在这里跟大家做一个简易的Demo来实现以上几个功能。