通过多个条件过滤 JavaScript 对象可以使用 Array 的 filter() 方法结合条件判断来实现。下面是一个示例代码:
// 假设有一个包含多个对象的数组
const data = [
{ id: 1, name: 'Alice', age: 25, gender: 'female' },
{ id: 2, name: 'Bob', age: 30, gender: 'male' },
{ id: 3, name: 'Charlie', age: 35, gender: 'male' },
{ id: 4, name: 'David', age: 28, gender: 'male' },
{ id: 5, name: 'Eve', age: 27, gender: 'female' }
];
// 定义多个过滤条件
const filters = {
age: 30,
gender: 'male'
};
// 使用 filter() 方法进行过滤
const filteredData = data.filter(item => {
for (let key in filters) {
if (item[key] !== filters[key]) {
return false;
}
}
return true;
});
console.log(filteredData);
上述代码中,我们定义了一个包含多个对象的数组 data
,以及一个包含多个过滤条件的对象 filters
。然后使用 filter()
方法对 data
数组进行过滤,通过遍历 filters
对象中的键值对,判断每个对象是否满足所有条件。最后,将满足条件的对象存储在 filteredData
数组中并输出。
这种方法可以根据需要灵活地添加、修改过滤条件,以实现多个条件的过滤。
领取专属 10元无门槛券
手把手带您无忧上云