js深复制

2018-08-26 17:27:18来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

一般来讲深复制主要是为了复制js对象中的引用类型,引用类型在普通的赋值操作下相当于是引用,修改复制对象也会影响原对象,简单的方法的话可以使用JSON.parse(JSON.stringify(obj)) 来实现深复制

然而这是没有考虑对象中有函数的情况,用var b = JSON.parse(JSON.stringify(a)) 这种方法的深复制没法复制对象里面的函数,而且属性的顺序也可能会出错。

这里记录一下用递归深复制可以复制函数的办法

        function isArray(o){
            return Object.prototype.toString.call(o)=='[object Array]';
        }
        function deepCopy(obj){
            var newObj ;
            if(isArray(obj)){
                newObj = [] ;
            }else if(typeof obj=="object"){
                newObj = {} ;
            }else if(typeof obj=="function"){
                return eval(obj.toString())
            }else{
                return obj ;
            }
            for(var key in obj){
                newObj[key] = arguments.callee(obj[key]) ;
            }
            return newObj ;
        }

其实函数的复制可以用eval(fun.otStrng())这样,加上对对象的判别,就完成里一个obj中有函数或者引用类型的复制。

注:es6中其实已经有isArray这个函数了,用法是Array.isArray(yourArr),返回一个bool值

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:Vue2开发大全

下一篇:react 的双向数据绑定