Angular2+>ConditionalObservableMapping
创始人
2024-10-22 06:30:57
0

在Angular 2+中,条件观察映射是一种常见的模式,它可以根据某些条件从一个Observable流中动态地选择不同的流。这可以通过使用rxjs中的一些操作符来实现,如switchMap、mergeMap、concatMap等。

下面是一个示例代码,在这个示例中,我们从一个http请求的observable流中获取用户数据,然后根据他们的年龄从不同的数据流中获取他们的就业数据。

import { Observable, of } from 'rxjs';
import { map, switchMap } from 'rxjs/operators';
import { HttpClient } from '@angular/common/http';

interface User {
  id: number;
  name: string;
  age: number;
}

interface Employment {
  id: number;
  userId: number;
  company: string;
  salary: number;
}

@Component({
  selector: 'app-user-employment',
  templateUrl: './user-employment.component.html',
  styleUrls: ['./user-employment.component.scss']
})
export class UserEmploymentComponent implements OnInit {
  users$: Observable;
  employments$: Observable;

  constructor(private httpClient: HttpClient) { }

  ngOnInit() {
    this.users$ = this.httpClient.get('/users');

    this.employments$ = this.users$.pipe(
      switchMap(users => {
        const youngUsers$ = of(users.filter(user => user.age < 25));
        const midAgeUsers$ = of(users.filter(user => user.age >= 25 && user.age <= 45));
        const oldUsers$ = of(users.filter(user => user.age > 45));

        return youngUsers$.pipe(map(() => this.httpClient.get('/youngUsersEmployments')))
          .pipe(switchMap(s => s), map((emps: any) => emps.result))
          .pipe(concat(midAgeUsers$.pipe(map(() => this.httpClient.get('/middleAgedUsersEmployments')))
            .pipe(switchMap(s => s), map((emps: any) => emps.result))))
          .pipe(concat(oldUsers$.pipe(map(() => this.httpClient.get('/oldUsersEmploy

相关内容

热门资讯

透视练习!newpoker脚本... 透视练习!newpoker脚本(透视)epoker透视(辅助)一贯一直都是有插件(哔哩哔哩)1、任何...
目前!菠萝德普辅助器免费版在哪... 目前!菠萝德普辅助器免费版在哪里(透视)兴动互娱技巧(果然是真的辅助下载)-哔哩哔哩1、下载好兴动互...
经核实!wepoker辅助软件... 经核实!wepoker辅助软件视频(透视)金虎爷有挂吗(其实有辅助插件)-哔哩哔哩1、在wepoke...
透视积累!红龙poker辅助(... 透视积累!红龙poker辅助(透视)pokerrrr2辅助(辅助)果然一直总是有工具(哔哩哔哩);1...
现有关情况通报如下!pokem... 现有关情况通报如下!pokemmo手机脚本辅助器(透视)透视辅助功能插件(好像真的是有辅助工具)-哔...
透视步骤!werplan怎么作... 透视步骤!werplan怎么作必弊(透视)拱趴大菠萝有挂吗(辅助)切实是有方法(哔哩哔哩)1、玩家可...
随着!扑克之星辅助(透视)浙江... 随着!扑克之星辅助(透视)浙江温州游戏辅助器(真是真的是有辅助工具)-哔哩哔哩1、浙江温州游戏辅助器...
透视学习!epoker免费透视... 透视学习!epoker免费透视脚本(透视)werplan免费挂下载(辅助)都是真的是有插件(哔哩哔哩...
据权威媒体报道!we poke... 据权威媒体报道!we poker游戏下(透视)创思维激k看底牌辅助开发商(原来有辅助神器)-哔哩哔哩...
透视演示!德州局透视(透视)i... 透视演示!德州局透视(透视)impoker辅助(辅助)切实一直总是有教程(哔哩哔哩)1、金币登录送、...