首頁  >  文章  >  web前端  >  改進版透過Json物件實現深複製的方法_json

改進版透過Json物件實現深複製的方法_json

WBOY
WBOY原創
2016-05-16 17:48:521218瀏覽

之前看到部落格的關於Json物件的深複製方法,即

複製程式碼 程式碼如下:

var obj = {
sayName: function() {
alert(this.name);
},
name:'靜水淵'
};var cloneObj=JSON.parse (JSON.stringify(obj));cloneObj.sayName();

但這種方式,不能複製屬性值是函數的屬性,因此改進了方法,以下是具體程式碼:
複製程式碼 程式碼如下:

var obj = {
sayName: function() { alert(this.name);
},
name:'靜水淵'
};
function clone(){
var str,newObj;
str= JSON .stringify(obj, function(key, value) {
return (typeof value == 'function' ? value.toString().replace(/^function(.*)/g, "jsonFunction$1") : value );
});
newObj = JSON.parse(str, function (key, value) {
if (/^jsonFunction(.*)/.test(value)) {
var strFun = '(' value.replace(/^jsonFunction(.*)/, "function$1") ')';
value = eval(strFun);
}
return value;
});
return newObj;
}
var cloneObj=clone(obj);
cloneObj.sayName();

因為還沒全面測試過,歡迎拍磚!
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn