首頁  >  文章  >  web前端  >  JavaScript物件深度克隆介紹_javascript技巧

JavaScript物件深度克隆介紹_javascript技巧

WBOY
WBOY原創
2016-05-16 16:28:171349瀏覽

也不知道從什麼時候開始,前端圈冒出了個新詞:物件深度克隆。看起來好像很高大上的樣子,實際上並不新鮮,在我們的實際專案開發中,你可能早已用到,只不過由於漢字的博大精深,有些原本很簡單的事物被一些看似專業的詞彙稍加修飾,就變得神秘起來了。

首先為什麼要將一個物件進行深克隆?請容許我進行一個猜測:你有時一定會認為js的內建物件document太長,那麼你可能會這樣做:

複製程式碼 程式碼如下:

var d = document;
d.by = function(id){
    return d.getElementById(id);
};
d.by('id').innerHTML = 'hello sentsin';

上述程式碼對document.getElementById進行了簡化,同時在原document物件中也增加了一個by的成員方法,你可以透過document.hasOwnProperty('by')傳回的狀態值來驗證你的判斷。再看下面一個例子。

複製程式碼 程式碼如下:

var person = {name: '賢心', profession: '前端開發', place: '杭州'};
var newPerson = person;
newPerson.age = '24';
console.log(person);
//結果:{name: '賢心', profession: '前端開發', place: '杭州', age: 24}

由此可見,將一個物件透過簡單的傳遞給一個新的變數時,僅僅只是為該物件增添了一個別名。這意味著,透過對該別名的操作,原有物件鍵值會改變。但問題在於,有時我們希望newPerson完全獨立於person,彼此之間不存在同步關係,那麼就需要產生一個副本,請看例子:

複製程式碼 程式碼如下:

var cloneObj = function(obj){
    var str, newobj = obj.constructor === Array ? [] : {};
    if(typeof obj !== 'object'){
        return;
    } else if(window.JSON){
        str = JSON.stringify(obj), //系列化物件
        newobj = JSON.parse(str); //還原
    } else {
        for(var i in obj){
            newobj[i] = typeof obj[i] === 'object' ?
            cloneObj(obj[i]) : obj[i];
        }
    }
    return newobj;
};


//測試
var obj = {a: 0, b: 1, c: 2};
var arr = [0, 1, 2];
//執行深度複製
var newobj = cloneObj(obj);
var newarr = cloneObj(arr);
//將複製後的新物件進行成員刪除
delete newobj.a;
newarr.splice(0,1);
console.log(obj, arr, newobj, newarr);
//結果: {a: 0, b: 1, c: 2}, [0, 1, 2], {b: 1, c: 2}, [1, 2];

這便是所謂的物件克隆。不過有幾處要解釋一下。程式碼中的JSON物件及其成員方法stringify和parse屬於ECMAScript5規範,它們分別負責將一個物件(包括陣列物件)轉換成字串,和還原,從而實現物件的深拷貝。那麼對於低階瀏覽器(如IE),拷貝數組的話,可以用newobj.concat(obj),而普通對象,就索性枚舉賦值好了。

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