Aurelia自定义绑定行为以观察对象的所有属性

时间:2018-11-04 22:15:39

标签: aurelia aurelia-binding aurelia-framework

我想创建一个自定义的绑定行为,使我能够检测到对对象属性的任何更改,如下所示:

<my-form model.bind="myObject & objectObserver:myObjChanged()"></my-form>

我知道我可以使用Aurelia的绑定引擎来创建属性观察器,也许可以将其构建到自定义的绑定行为中以检测对象的属性并为每个对象创建属性观察器。但是我无法理解在自定义绑定行为中提供给我的绑定对象。到目前为止,这是我的代码:

import { inject, bindingBehavior, BindingEngine } from 'aurelia-framework';

@bindingBehavior('objectObserver')
@inject(BindingEngine)
export default class ObjectObserverBindingBehavior {
  constructor(bindingEngine) {
    this.bindingEngine = bindingEngine;
  }

  bind(binding, scope, interceptor) {
    console.warn('hello', binding, scope, interceptor);
  }

  unbind(binding, scope) {
    console.warn('observer.unbind()', binding, scope);
  }
}

当发生绑定并且输出了控制台文本时,我看到了 enter image description here

所以我知道它正在工作,但我不知道开始观看的最佳对象是什么。我看到targetObserver.currentValue内部的绑定对象。那是开始观看的最佳财产吗?有没有其他方法可以利用Aurelia绑定引擎的现有功能?

1 个答案:

答案 0 :(得分:1)

我基于Javascript中内置的Proxy功能,发现了不是Aurelia特定的解决方案。

export function onChangeObj(object, onChange) {
  // creates Proxy to detect changes in object properties and call a function
  if (typeof onChange !== 'function' || typeof object !== 'object') {
    throw new Error('onChangeObj: incorrect parameters');
  }
  const handler = {
    set(obj, prop, value) {
      onChange(prop, value);
      return Reflect.set(obj, prop, value);
    },
  };
  return new Proxy(object, handler);
}

要使用它,只需像这样调用它:

this.myObject = onChangeObj(this.myObject, () => this.myObjChanged());

有效地,该对象将被包装代理替换,该包装代理每次修改一个属性(使用setter方法)时都会调用提供的函数。

如果有人通过Aurelia Binding Behavior找到解决方案,我仍然会感兴趣。