Property change subscription with Aurelia

前端 未结 4 1566
栀梦
栀梦 2020-11-30 04:03

I have a property on my viewmodel which I want to listen to and trigger events based on its value, like this:

class viewModel {
  constructor() {
    this.va         


        
4条回答
  •  离开以前
    2020-11-30 04:38

    In some plugins I've been using DI to get the ObserverLocator instance from the container:

    import {inject} from 'aurelia-dependency-injection';  // or from 'aurelia-framework'
    import {ObserverLocator} from 'aurelia-binding';      // or from 'aurelia-framework'
    
    @inject(ObserverLocator)
    export class Foo {
        constructor(observerLocator) {
            this.observerLocator = observerLocator;
        }
        ...
    }
    

    You can then do something like this:

    var subscription = this.observerLocator
        .getObserver(myObj, 'myPropertyName')
        .subscribe(myCallback);
    

    When you're ready to dispose of the subscription, invoke it:

    subscription();
    

    I think this is all subject to change but it's something you could use right now if you needed to.

    More info here

    October 2015 update

    The ObserverLocator is Aurelia's internal "bare metal" API. There's now a public API for the binding engine that could be used:

    import {inject} from 'aurelia-dependency-injection';  // or from 'aurelia-framework'
    import {BindingEngine} from 'aurelia-binding';        // or from 'aurelia-framework'
    
    @inject(BindingEngine)
    export class ViewModel {
      constructor(bindingEngine) {
        this.obj = { foo: 'bar' };
    
        // subscribe
        let subscription = bindingEngine.propertyObserver(this.obj, 'foo')
          .subscribe((newValue, oldValue) => console.log(newValue));
    
        // unsubscribe
        subscription.dispose();
      }
    }
    

提交回复
热议问题