這篇文章主要介紹了javascript中clone物件的方法,需要的朋友可以參考下。
開發中,打斷物件間的引用關係,只想下個副本的情況無所不在,clone一個物件就在所難免了。
JavaScript中,簡單的方法就是用JSON函數,將物件stringify成字串,再parse成一個新物件。要嘛就是從網路搜尋程式碼,開源社群裡面clone的程式碼還是有不少的。
程式碼雖然可以找得到,但,東西永遠是別人的,動手學著碼永遠是個不變的主題。
自己寫了兩個克隆的函數:
cloneOwn:複製自訂物件的自有屬性,不包含繼承的屬性,屬性可以是基本資料型別和陣列,自訂的對象,可以製定要複製的屬性名稱清單。
cloneArray: 克隆數組,數組內的元素可以是對象,基本類型。
//第一个参数是被克隆的对象,第二个参数是需要克隆的属性列表 function cloneOwn() { var obj = arguments[0]; if (typeof obj === 'undefined' || obj === null) return {}; if (typeof obj !== 'object') return obj; //第二个参数是属性名称列表,就采用该列表进行刷选 //否则就克隆所有属性 var attrs = arguments[1]; var enable_spec_attr = true; if (!(attrs instanceof Array)) { //console.log(attrs); attrs = obj; enable_spec_attr = false; } var result = {}; var i; for (i in attrs) { attr = enable_spec_attr? attrs[i]: i; //console.log(attr); if (obj.hasOwnProperty(attr)) { if (obj[attr] instanceof Array) { result[attr] = cloneArray(obj[attr]); } else if (typeof obj[attr] === 'object') { result[attr] = cloneOwn(obj[attr]); } else { result[attr] = obj[attr]; } } } return result; }
//克隆数组 function cloneArray(array) { if (typeof array === 'undefined' || array === null) return []; if (!(array instanceof Array)) return []; result = []; var i; for(i in array) { if (typeof array[i] !== 'object') { result[i] = array[i]; continue; } //clone object result[i] = cloneOwn(array[i]); } return result; }
呼叫
1.常規複製自訂物件:
var a = { name:'frank', age:20 }; var b= cloneOwn(a);
2.指定複製的屬性
var a = { name:'frank', age:20, address:'any where' }; var b = cloneOwne(a, ['name', 'age']);3.克隆內含有數組屬性的自訂物件
var a = { name: 'kxh', age: 20, books: ['hai','ho','ali'], likes: [ {wname: 'kaili', wage: 81, fav: "aaaaa"}, {wname: 'seli', wage: 82, fav: "bbb"}, {wname: 'ailun', wage: 83, fav: "ccc"},] }; var b = cloneOwne(a);4.克隆數組,內含有自訂物件
var a = [ { name:'frank', age:20 }, { name:'leon', age:30 } ]; var b = cloneArray(a);上面的程式碼還是有很多問題的,例如,內建物件的克隆就存在點問題,例如datatime類型。 問題管問題,這樣一個學習過程也是要有的。