笼统decorator形式
运用jQuery的装潢者形式
jQuery.extend()许可我们在运行时或许在随后一个点上动态地将两个或两个以上的对象(和它们的属性)一同扩大(或兼并)为一个单一对象。
定义三个对象: defaults、options、settings,目标是为了装潢defaults对象,将options的分外功用附加到defaults上。
var decoratorApp = decoratorApp || {};
//定义要运用的对象
decoratorApp = {
defaults: {
validate: false,
limit: 5,
name: "foo",
welcome: function(){
console.log("welcome!");
}
},
options:{
validate: true,
name: "bar",
helloWorld: function(){
console.log("hello,world");
}
},
settings: {},
printObj: function(obj){
var arr = [],
next;
$.each(obj,function(key,val){
next = key + ":";
next += $.isPlainObject(val) ? printObj(val) : val;
arr.push(next);
});
return "{" + arr.join(",") + "}";
}
};
decoratorApp.settings = $.extend({},decoratorApp.defaults,decoratorApp.options);
//打印
decoratorApp.printObj(decoratorApp.settings);