Расширить объект установки по умолчанию
Как вы все знаете, кнопка - это кнопка... нажмите, вверх, вниз, сделайте это, сделайте это. Поэтому я написал поведение кнопки по умолчанию "класс / объект".
внешний по умолчанию 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
}
включите button.js в html и продлите кнопку "Класс / Объект":
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)';
}
}
});
Это почти работает, но убивает инициализированную кнопку Button.
Object.defineProperty(Button.prototype,"initialized", {
set : function( bool ) {
this._initialized = bool;
if(this.initialized === true) {
this.buttonStyle = "NONE";
}
}
});
Как я могу расширить оригинальный сеттер?
1 ответ
То, что вы спрашиваете, кажется необычным, но давайте попробуем. Прежде всего, рассмотрим этот базовый класс, который будет в вашем внешнем js-файле:
// Constructor
function Button() {
var self = this;
var _initialized = false; // 'private' property manipulated by the accessors
this.initialized = false;
this.createButton();
this.initialized = true;
}
// Default prototype
Button.prototype = {
createButton: function() {
console.log(' create DOM element ');
}
}
// Default getter/setter on prototype
Object.defineProperty(Button.prototype,"initialized", {
set : function( bool ) {
console.log('this is the original setter');
this._initialized = bool;
if(this._initialized === true) {
console.log('do default stuff')
}
},
get : function() {
return this._initialized;
},
configurable : true // IMPORTANT: this will allow us to redefine it
});
Если я понимаю, что вы спрашиваете, вы хотите переопределить initialized
accessor (getter/setter), но все же есть ссылка на старый. Возможно, есть лучший способ сделать это, но вы можете скопировать оригинальный метод доступа в новый, а затем переопределить его:
// Keep reference to the old accessors
var original = Object.getOwnPropertyDescriptor(Button.prototype, 'initialized');
Object.defineProperty(Button.prototype, "oldInitialized", {
set : original.set,
get : original.get
});
// Redefine getter and setter
Object.defineProperty(Button.prototype, "initialized", {
set : function( bool ) {
console.log('this is the new setter');
this.oldInitialized = bool;
},
get : function() {
return this._initialized;
}
});
Вот этот код на работе: http://jsfiddle.net/aTYh3/.