私が望むのは、JavaScript プロパティをラップして get/set の動作を変更できる機能です。
値であるプロパティの場合、次のことができます。
var obj = {
myProperty : 0
};
function notifyOfChange(obj, propertyName) {
var propertyValue = obj[propertyName];
Object.defineProperty(obj, propertyName, {
get : function() { return propertyValue; },
set : function(newValue) {
var propertyValue = newValue;
console.log("Message from notifyOfChange.");
}
});
};
obj.myProperty = 10; // outputs "Message from notifyOfChange."
しかし、myPropertyが既に getter/setter を持っている場合はどうなるでしょうか?
var obj = Object.create({}, {
myProperty : {
get : function() { return this._myProperty; },
set : function(value) {
console.log("Message from obj itself.");
this._myProperty = value;
},
configurable : true
}
});
obj.myProperty = 10; // outputs "Message from obj itself";
notifyOfChange(obj, "myProperty");
obj.myProperty = 10; // outputs "Message from notifyOfChange."
myProperty匿名セッターを検出して、 notifyOfChange で呼び出せるようにする方法はありますか?
注: notifyOfChange を任意のオブジェクトで機能させたいので、myPropertyセッターに名前付き関数を使用するだけでは機能しません。