角度多重过滤可观察,rxJS

时间:2020-04-29 16:02:31

标签: angular rxjs observable filtering

您好,我想使用3倍过滤器输入(1x input:text, 2x select)。我有一个可观察的列表userList$: Observable<User[]>。在ngOnInit()中,我使用input:text过滤此列表。

userList$: Observable<User[]>
inputControl = new FormControl();  // input type text
selectStatus = new FormControl();  // select
filteredData$:any;

ngOnInit(){
   this.filteredData$ = combineLatest(
      this.userList$,
      this.inputControl.valueChanges.pipe(
        startWith(""),
        debounceTime(400)
      )
    ).pipe(
      distinctUntilChanged(),
      filter(([list, input]) => Boolean(list)),
      map(([list, input]) => {
        return list.filter(
          ({login}) => !input || login.toLowerCase().indexOf(input) !== -1);
      })
    );  
    this.userList$ = this.filteredData$;
}

当我添加一个过滤器时,第一个过滤器不起作用。当我使用2倍过滤器时的代码:

ngOnInit(){
    this.filteredData$ = combineLatest(
      this.userList$,
      this.inputControl.valueChanges.pipe(
        startWith(""),
        debounceTime(400)
      )
    ).pipe(
      distinctUntilChanged(),
      filter(([list, input]) => Boolean(list)),
      map(([list, input]) => {
        return list.filter(
          ({login}) => !input || login.toLowerCase().indexOf(input) !== -1);
      })
    );  
    this.filteredData$ = combineLatest(
      this.userList$,
      this.selectStatus.valueChanges.pipe(
        startWith(""),
        debounceTime(400)
      )
    ).pipe(
      distinctUntilChanged(),
      filter(([list, input]) => Boolean(list)),
      map(([list, input]) => {
        if(input == 1){
          return list.filter(
            ({is_banned, is_deleted}) =>  is_banned !== 1 || is_deleted !== 1);
        }else if (input == 2){
          return list.filter(({is_banned}) => is_banned == 1 );
        }else{
          return list.filter(({is_deleted}) => is_deleted == 1 );
        }
      })
    );
    this.userList$ = this.filteredData$;
 }

使用3x过滤字段时如何过滤此列表?

0 个答案:

没有答案