js 封装的一个深拷贝的方法

1.首先判断一下要拷贝数据的数据类型,

一共有三种方法

1).typeof data

2).JSON.parse(JSON.stringify(data))

3).使用万能法

Object.prototype.toString.call

我们这里使用万能法加字符串的slice截取方法,进行判断并把对应的类型截取出来备用。

//获取数据的具体的数据类型,并且返回
        function getType(data) {
            // console.log(Object.prototype.toString()); //返回数据具体的数据类型
            // .call() 改变this的指向
            // console.log(Object.prototype.toString.call(data).slice(8,-1));
            return Object.prototype.toString.call(data).slice(8, -1)
        }
        

2.进行拷贝

function deepCopy(data) {
            //1.先声明一个空数组,空对象
            //调用getType方法来判断是什么类型的数据
            if(getType(data) == "Array"){
                var res = [];
            }else if(getType(data) == "Object"){
                var res = {};
            }


            //2.循环将原有数据中的内容,一个一个复制到空数据里面
            for(var key in data){
                //3.如果复制的值还是 引用数据类型,这个部分也需要进行深拷贝
                if(getType(data[key]) == "Array" || getType(data[key]) == "Object"){
                    res[key] = deepCopy(data[key]);
                }else{
                    res[key] = data[key];
                }
            }
           
            //4.返回复制好的对象
            return res;
            
        }

你可能感兴趣的:(js,javascript)