首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角7中可观测无标的简便方法

角7中可观测无标的简便方法
EN

Stack Overflow用户
提问于 2018-12-09 10:35:08
回答 1查看 706关注 0票数 0

我有一个实现,当使用takeUntil销毁组件时,它会自动取消可观察到的订阅。但是在许多组件中实现相同的代码是很烦人的。

我想知道这是否可以简化(我不能使用async管道,因为我需要在类型记录组件中发出的值)

以下是我目前的实现:

代码语言:javascript
复制
export class Component implements OnDestroy {
    _dstr = new Subject();

    data$: Observable<any> = this.store.select(Selector.getData);

    constructor(
        private store: Store<State>,
    ) {
        this.store.pipe(
            select(Selector.getOtherData),
            takeUntil(this._dstr),
        ).subscribe(data => {
            console.log('here is my data!', data)
        });
    }

    public ngOnDestroy(): void {
        this._dstr.next();
        this._dstr.complete();
    }

}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-12-09 10:54:30

您可以收集数组中的所有订阅,并在ngOnDestroy函数中取消订阅每个订阅。如果您经常需要这种行为,您可以考虑使用一个抽象类,从抽象类中扩展所有为您服务的组件。

代码语言:javascript
复制
import { Component, OnDestroy, OnInit } from '@angular/core';
import { Subscription, Observable, of } from 'rxjs';

export abstract class BaseComponent implements OnDestroy{
  public subscriptions: Subscription[] = [];

  public ngOnDestroy(): void {
    console.log("destroyed");
    this.subscriptions.forEach(s => s.unsubscribe());
  }
}

@Component({
  selector: 'my-app',
  templateUrl: './app.component.html',
  styleUrls: [ './app.component.css' ]
})
export class AppComponent {

}

let count: number = 0;
@Component(
  {
    selector: 'app-derived',
    template: 'Derived Class'
  }
)
export class DerivedComponent extends BaseComponent implements OnInit, OnDestroy {
  private store: Observable<any> = of(count++);
  constructor() {
    super();
  }
  public ngOnInit(): void {
    this.subscriptions.push( this.store.subscribe(data => console.log(data)) );
  }
}

闪电战演示:https://stackblitz.com/edit/angular-peyoac

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53691396

复制
相关文章

相似问题

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