What I'd like is the ability to wrap a JavaScript property to modify behavior on get/set.
For properties that are values, I can do the following:
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."
However, what if myProperty already has a 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."
Is there a way to detect the myProperty anonymous setter so that I can call it in notifyOfChange?
Note: I'd like to make notifyOfChange work with any object, so just using a named function for the myProperty setter doesn't work.