Javascript實現對象的深度合併

function extend() {
var extended = {};
var deep = false;
var i = 0;

// 判斷是否爲深拷貝
if (Object.prototype.toString.call(arguments[0]) === '[object Boolean]') {
deep = arguments[0];
i++;//若是爲深拷貝則初始的i爲1或者爲0
}

// 將對象屬性合併到已存在的對象中
var merge = function(obj) {
for (var prop in obj) {
if (obj.hasOwnProperty(prop)) {
// 若是屬性爲對象而且須要深拷貝時則使用函數遞歸、反之則將當前的屬性替換現有的屬性
if (deep && Object.prototype.toString.call(obj[prop]) === '[object Object]') {
  extended[prop] = extend(extended[prop], obj[prop]);
} else {
  extended[prop] = obj[prop];
}
  }
  }
};

// 遍歷全部對象屬性
for (; i < arguments.length; i++) {
  merge(arguments[i]);
}

return extended;

}
 
示例:
  一、extend({a:1,b:2,c:3},{a:2,d:5})簡單拷貝
  二、extend(true,{a:1,b:2,c:3},{a:2,d:5,b:{a:123}})簡單拷貝
相關文章
相關標籤/搜索