我正在尝试对表中多个属性上的多个值实施过滤器管道。
我能够在一个属性上过滤多个值。但是我无法对多个属性的多个值执行此操作。
我的管道过滤器实现针对单个属性中的多个值
<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'}]
任何人都可以帮助我解决这个逻辑问题。
答案 0 :(得分:0)
您的代码逻辑错误是,如果您希望仅在所有过滤器都匹配时返回true,则如果任何过滤器都匹配则返回true
。
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]);
});
});
}