像大家都知道一個按鈕是一個按鈕...點擊,上,下,做到這一點,做到這一點。 所以我寫了一些默認的按鈕行爲「class/object」。擴展二傳手默認對象
外部默認button.js:
function Button(parent) {
var self = this;
this.enabled = true;
this.visible = true;
...
this.initialized = false;
f_createButton(parent, self);
this.initialized = true;
...
}
Button.prototype = {
get initialized() {
return this._initialized;
},
set initialized(bool){
this._initialized = bool
if(this.initialized === true) {
... do default stuff
}
},
get enabled(){
return this._enabled;
},
set enabled(bool){
this._enabled = bool;
if(document.getElementById(this.id)) { // is button defined?
var mClassName = document.getElementById(this.id).children[0].className;
document.getElementById(this.id).className = (this.enabled === false) ? "button button-Gray_disabled" : "button button-" + this.defaultStyle;
document.getElementById(this.id).children[0].className = (this.enabled === false) ? mClassName + "_disabled" : mClassName.replace("_disabled","");
}
}
}
function f_createButton("", obj) {
.... create DOM element
}
包括在HTML & button.js延長按鈕 「類/對象」:
Object.defineProperty(Button.prototype,"buttonStyle", {
get : function() {
return this._buttonStyle;
},
set : function(str) {
this._buttonStyle = str;
if(this.id !== "undefined" && document.getElementById(this.id)) { // is button defined?
document.getElementById(this.id).style.backgroundImage = 'url(Images/'+this.buttonStyle+'/buttons.png)';
}
}
});
這幾乎工作,但它殺死初始化原來的按鈕。
Object.defineProperty(Button.prototype,"initialized", {
set : function(bool) {
this._initialized = bool;
if(this.initialized === true) {
this.buttonStyle = "NONE";
}
}
});
如何擴展原始二傳手?
這個想法是不改變外部button.js ... – 2013-04-04 21:22:47
即時通訊,有點兒新.... PHP是我的語言... – 2013-04-04 21:26:04
簡單,我想添加一些擴展功能button.js和趕上初始化事件...也許我錯了我的代碼吸盤? – 2013-04-04 21:38:00