RxJS. Подписка в подписке

Когда к нам в компанию приходят новые ребята, то обязательно делают подписку в подписке. Чтобы её избежать в простейшем случае надо использовать операторы mergeMap или switchMap.

import { of } from 'rxjs';
import { map, mergeMap } from 'rxjs/operators';

// грязно (subscribe hell)
of('Hello').subscribe(h => {
  of(h + ' world').subscribe(hw => {
    of(hw + '! (1)').subscribe(console.log)
  });
});

// лаконично. mergeMap или switchMap
of('Hello').pipe(
  mergeMap(h => of(h + ' world')),
  mergeMap(hw => of(hw + '! (2)')),
).subscribe(console.log);

Stackblitz

Похожие записи

Angular. Когда не надо отписываться в RxJS?

В async pipe за вас отпишется Angular. Во всех остальных случаях лучше отписываться самостоятельно. Допускается не отписываться в потоках, где будет гарантировано вызван complete.

Builder в JS

Builder (cтроитель) - порождающий шаблон программирования. Применяется для создания сложных объектов при помощи цепочки методов someBuilder->setValueA(1)->setValueB(2)->build()