JS案例 - 多筛选条件过滤数据

复制代码,点击这里查看结果~

方法一

let data = [ {
        name: '国-红楼梦',
        price: 123,
        stock: 108
    }, {
        name: '国-西游记',
        price: 99,
        stock: 151
    }, {
        name: '国-水浒传',
        price: 708,
        stock: 72
    }, {
        name: '国-三国演义',
        price: 58,
        stock: 72
    }, {
        name: '外-荆棘鸟',
        price: 45,
        stock: 65
    }, {
        name: '外-格列佛游记',
        price: 69,
        stock: 151
    }, {
        name: '外-荷马史诗',
        price: 48,
        stock: 123
    } ]

function filter(condition, data){
    return data.filter( item => {
        return Object.keys( condition ).every( key => {
            return String( item[ key ] ).toLowerCase().includes(
                String( condition[ key ] ).trim().toLowerCase() )
        } )
    } )
}

//无条件
var condition={name: '',price: ''};
var aa = filter(condition,data);
console.log("=== 无条件 ===");
console.log(aa);

//单条件
var condition={name: '国'};
var bb = filter(condition,data);
console.log("=== 单条件 ===");
console.log(bb);
//多条件
var condition={name: '国',stock: 72};
var cc = filter(condition,data);
console.log("=== 多条件 ===");
console.log(cc);

方法二

let data = [ {
        name: '国-红楼梦',
        price: 123,
        stock: 108
    }, {
        name: '国-西游记',
        price: 99,
        stock: 151
    }, {
        name: '国-水浒传',
        price: 708,
        stock: 72
    }, {
        name: '国-三国演义',
        price: 58,
        stock: 72
    }, {
        name: '外-荆棘鸟',
        price: 45,
        stock: 65
    }, {
        name: '外-格列佛游记',
        price: 69,
        stock: 151
    }, {
        name: '外-荷马史诗',
        price: 48,
        stock: 123
    } ]
 
let name= ['国-西游记', '外'];
let price= [123, 48, 69];
let stock= []; 
let result = data.filter((a,i)=>{ 
    return (stock.some(f => (f === a.stock)) && price.some(f => (f === a.price)) || name.some(f => (a.name.includes(f))) ) 
});
console.log(result);
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值