首頁  >  文章  >  web前端  >  js實現深複製程式碼分享

js實現深複製程式碼分享

小云云
小云云原創
2018-02-26 15:28:412095瀏覽

關於js實現深複製,首先要明白的就是,要實現對複雜物件的複製,用到的就是遞歸的想法。下面就是透過程式碼一步步來實現並講解。

function deepClone(data1,data2){
        var data2 = data2 || {}; //局部变量data2赋初值为接收的参数或者为一个空对象。
        for(var key in data1){            if(typeof data1[key] === 'object'){ //依次判断data1对象的属性是不是对象
                data2[key] =  (data1[key].constructor===Array) ? [] : {}                //判断要复制的项是对象还是数组
                deepClone(data1[key],data2[key]); //递归实现
            }else {
                data2[key] = data1[key] //如果不是的可以直接相等
            }
        }        return data2;
    }    var json = {"name":"小倪子麻麻","age": "20",arr1:[2,3,4,5]};    var json1 = {};
    json1 = deepClone (json,json1);
    json.arr1.pop();
    console.log(json); //{"name":"小倪子麻麻","age": "20",arr1:[2,3,4]};
    console.log(json1);//{"name":"小倪子麻麻","age": "20",arr1:[2,3,4,5]};

相關推薦:

php中關於淺複製和深複製的詳解

JavaScript物件的深複製

Java中物件的深複製(深複製)與淺複製(淺克隆)序列化

以上是js實現深複製程式碼分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn