以下是一个示例代码,展示了如何按照对象值过滤对象数组:
// 假设有一个对象数组
const array = [
{ name: 'Alice', age: 25 },
{ name: 'Bob', age: 30 },
{ name: 'Charlie', age: 35 },
{ name: 'David', age: 40 }
];
// 定义一个过滤函数,接收一个对象参数和一个过滤条件对象参数
function filterArray(obj, filter) {
// 遍历过滤条件对象的每个键值对
for (let key in filter) {
// 如果对象的属性值与过滤条件的属性值不匹配,则返回 false
if (obj[key] !== filter[key]) {
return false;
}
}
// 如果所有条件都匹配,则返回 true
return true;
}
// 定义一个过滤条件对象
const filter = { age: 30 };
// 使用 filterArray 函数过滤对象数组
const filteredArray = array.filter(obj => filterArray(obj, filter));
console.log(filteredArray);
// 输出: [{ name: 'Bob', age: 30 }]
这段代码首先定义了一个对象数组 array
,然后定义了一个过滤函数 filterArray
。该函数接收一个对象参数 obj
和一个过滤条件对象参数 filter
。在函数中,它会遍历过滤条件对象的每个键值对,并将对象的属性值与过滤条件的属性值进行比较。如果有任何一个属性值不匹配,则返回 false;否则,返回 true。然后,使用数组的 filter
方法,将过滤函数作为参数传递进去,对对象数组进行过滤,最终返回符合过滤条件的对象数组。
在上述示例中,过滤条件对象 filter
的属性是 age: 30
,因此最终过滤出的结果是只包含 age
属性为 30 的对象。