Yem*_*lat 2 javascript oop setter defineproperty
我需要这样做,以便每次更改对象上的特定属性时 - 它都会在同一对象上调用特殊方法。
例子:
MyObject.prototype = Object.create({
specialMethod: function() { /* ... */ }
}, {
someValue: {
set: function(value) {
/* HOW DO I ASSIGN THE VALUE TO MyObject HERE?*/
/* I can't do: this.someValue=value, that would create endless recursion */
this.specialMethod();
}
}
});
Run Code Online (Sandbox Code Playgroud)
如何在属性设置器中将值分配给 MyObject?
getter/setter 属性中没有存储位置,您不能在其上存储值。您需要将它存储在其他地方并为此创建一个吸气剂。两种解决方案:
使用第二个“隐藏”属性:
MyObject.prototype.specialMethod: function() { /* ... */ };
Object.defineProperty(MyObject.prototype, "someValue", {
set: function(value) {
this._someValue = value;
this.specialMethod();
},
get: function() {
return this._someValue;
}
});
Run Code Online (Sandbox Code Playgroud)使用闭包变量(通常在构造实例时创建):
function MyObject() {
var value;
Object.defineProperty(this, "someValue", {
set: function(v) {
value = v;
this.specialMethod();
},
get: function() {
return value;
}
});
}
MyObject.prototype.specialMethod: function() { /* ... */ };
Run Code Online (Sandbox Code Playgroud)