例子:
let foo = {bar: 'baz', method() { this.bar = 'baz2' }}
let fooProxy = new Proxy(foo, {set(target, key, val) { console.log('set trap triggered!') }})
fooProxy.bar = 'any value' // as expected: set trap triggered!
foo.method() // trap not triggered
为什么会这样?即使从目标对象内部,如何触发陷阱?
编辑,主要是为了向@Bergi解释这一点:
我的主要目标是拦截对 foo 对象的任何更改,因此我可以将属性(例如 foo.changed)设置为 true。另外,我想拦截对具有数组/对象类型的 foo 属性的更改。你知道,如果我设置 foo 的属性,一切都很好,但是当我推送到一个数组时,代理无法拦截它。所以我也需要将数组/对象属性转换为代理(我称它们为 ArrayProxy 和 ObjectProxy)。
这是我的代码(打字稿):
// Category.ts
class Category extends Model {
title: string = ''
products: Product[] = []
}
// Model.ts
abstract class Model extends BaseModel {
constructor() {
return new Proxy(this, {
set (target, key, val) {
if (Array.isArray(val) {
target[key] = new ArrayProxy(val) // I WANT all array properties to be ArrayProxy but the problem (see below) not let me do that
}
}
})
}
}
// BaseModel.ts
abstract class BaseModel {
constructor(attributes) {
this.setAttributes(attributes)
}
setAttributes(attributes) {
Object.keys(attributes).forEach((key) => {
this[key] = attributes[key] // THE PROBLEM
})
}
}
我已经删除了代码,这并不重要(例如对象属性和 ObjectProxy 的类似情况)。
如果有更优雅的方式来做我所做的事情,我将非常感激。