表格列的多个值上的角度过滤器管道

时间:2019-05-07 15:46:24

标签: angular typescript angular-filters angular-pipe

我正在尝试对表中多个属性上的多个值实施过滤器管道。

我能够在一个属性上过滤多个值。但是我无法对多个属性的多个值执行此操作。

我的管道过滤器实现针对单个属性中的多个值

<exclude>

给出了我的输入数组,

import { Pipe, PipeTransform } from '@angular/core';

@Pipe({
  name: 'vFilter',
  pure: false
})

export class VFilterPipe implements PipeTransform {

  transform(vList: any[], vfilter?: any): any {
    if (!vList|| !Object.keys(vfilter).length) {
      return vList;
    } 
    return vList.filter(item => {
          for (let key in vfilter) {
            for(let value in vfilter[key]){
             if ((item[key] === undefined || item[key] == vfilter[key][value])) 
             {
              return true;
             }
           }
           return false;
         }
         return false;
       });
  }
}

我希望过滤后的输出如下所示

vList = [{'name':'jack','age':'25'},{'name':'sam','age':'25'},{'name':'smith','age':'25'},{'name':'jack','age':'28'}]

vfilter = {'name':['jack','sam'],'age':['25']}

但是我得到以下结果,

vList = [{'name':'jack','age':'25'},{'name':'sam','age':'25'}]

任何人都可以帮助我解决这个逻辑问题。

1 个答案:

答案 0 :(得分:0)

您的代码逻辑错误是,如果您希望仅在所有过滤器都匹配时返回true,则如果任何过滤器都匹配则返回true

stackblitz

transform(vList: any[], vfilter?: any): any {
  if (!vList || !Object.keys(vfilter).length) {
    return vList;
  } 
  return vList.filter(item => {
          return Object.keys(vfilter)
            .filter(_ => vfilter.hasOwnProperty(_))
            .every(key => {
              if(!item[key]) return true; // matches undefined value
              const arrayValues = vfilter[key] as any[];
              return arrayValues.some(_ => _ === item[key]);
          });
      });
}