首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >mobx &mobx角:如何从商店更新和订阅更新的值?

mobx &mobx角:如何从商店更新和订阅更新的值?
EN

Stack Overflow用户
提问于 2018-09-21 06:35:05
回答 1查看 1.2K关注 0票数 3

我有棱角应用程序v6,我使用的是mobxmobx-angular的最新版本(您可以在依赖项中看到)。我来自ngrx,ngxs背景,所以很难理解mobx流,因为它或多或少地带有额外的angular-service方法(还有性能)。

在stackblitz的例子中,我几乎没有问题。我希望有人能给他们指点。

演示应用程序

store.ts

代码语言:javascript
复制
@Injectable()
export class Store {

    @observable counter: number = 0;

    constructor() { }

    @action count() {
        this.counter ++;
    }
}

app.component.ts

代码语言:javascript
复制
export class AppComponent  {

  _counter:number=0;

  constructor(private store:Store){}

  ngOnInit(){
    // how to subscribe to updated value of counter from service and assign it to this._counter ????

    this._counter = this.store.counter;
  }
}

app.component.html

代码语言:javascript
复制
    <div *mobxAutorun>Counter : {{store.counter}}<br /></div>

______________________________________________

<div>Counter : {{store.counter}}<br /></div>

______________________________________________


<div>how to subscribe to updated value form 'counter' variable to '_counter' local variable????</div><br />

<div> {{_counter}} </div>

<button (click)="store.count()">Count</button>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-09-22 22:28:10

您可以在ngOnInit中设置RxJ订阅。

代码语言:javascript
复制
ngOnInit() {
  this.store.toRx(this.store, 'counter')
    .subscribe(val => this._counter = val)
}

toRx是一个方便的功能,可以添加到商店。

它使用Mobx observe()函数,它只在每次指定项更改时激活回调。

代码语言:javascript
复制
import { Injectable } from '@angular/core';
import { action, observable, observe } from 'mobx';
import { Observable } from 'rxjs';

@Injectable()
export class Store {
  ...
  toRx(obj, prop) {
    return Observable.create(observer =>
      observe(obj, prop, (change) => observer.next(change.newValue), true)
    );
  }
}

如果您有要订阅的深度嵌套属性,例如

代码语言:javascript
复制
@Injectable()
export class Store {
  ...    
  @observable counterWrapper = { counter: 0 };

只需更改toRx的第一个参数

代码语言:javascript
复制
this.store.toRx(this.store.counterWrapper, 'counter')
  .subscribe(val => this._counter = val)
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52437928

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档