把数组对象里面对象过滤成一个新的数组
时间: 2023-10-08 17:10:21 浏览: 146
你可以使用数组的 `filter` 方法来过滤数组对象,并生成一个新的数组。在 `filter` 方法中,你可以使用条件语句来判断是否保留某个对象。以下是一个示例代码:
```javascript
const array = [
{ id: 1, name: 'John' },
{ id: 2, name: 'Jane' },
{ id: 3, name: 'Alice' },
];
const filteredArray = array.filter(obj => obj.id > 1);
console.log(filteredArray);
```
上述代码中,我们使用 `filter` 方法来保留 `id` 大于 1 的对象,并将结果存储在 `filteredArray` 中。输出结果为:
```
[
{ id: 2, name: 'Jane' },
{ id: 3, name: 'Alice' },
]
```
你可以根据自己的需求修改条件语句来实现更复杂的过滤逻辑。
相关问题
在数组对象中如何过滤出一个对象
可以使用数组的 `filter()` 方法来过滤出符合条件的对象。
例如,假设有一个名为 `students` 的数组对象,其中包含多个学生对象,每个学生对象都有一个 `name` 和 `age` 属性。要过滤出年龄为 18 岁的学生对象,可以使用以下代码:
```javascript
const students = [
{ name: 'Alice', age: 17 },
{ name: 'Bob', age: 18 },
{ name: 'Charlie', age: 19 }
];
const filteredStudents = students.filter(student => student.age === 18);
console.log(filteredStudents); // 输出 [{ name: 'Bob', age: 18 }]
```
这里使用了箭头函数和比较操作符来判断每个学生对象的年龄是否等于 18。 `filter()` 方法将返回一个新的数组,其中只包含符合条件的学生对象。在这个例子中,将返回包含一个学生对象的数组,即 `{ name: 'Bob', age: 18 }`。
js 中对一个对象数组过滤, 过滤条件是每一个对象的某个属性值在不在另外一个数组对象中
在JavaScript中,如果你有一个对象数组,并想要基于每个对象的特定属性值来过滤,你可以结合 `Array.prototype.filter()` 方法和数组的 `includes()` 方法来实现。假设你有一个对象数组 `objArray` 和一个用于比较的属性名 `propName`,以及另一个数组 `excludeArray`,你可以这样做:
```javascript
function filterObjects(objArray, propName, excludeArray) {
return objArray.filter(obj => {
const value = obj[propName]; // 获取当前对象的指定属性值
return excludeArray.indexOf(value) === -1; // 判断属性值是否不在排除数组中
});
}
// 示例
const objArray = [
{ id: 1, name: 'A' },
{ id: 2, name: 'B' },
{ id: 3, name: 'C' },
{ id: 4, name: 'D' },
];
const excludeArray = ['B', 'D'];
const filteredArray = filterObjects(objArray, 'name', excludeArray);
console.log(filteredArray); // 输出:[ { id: 1, name: 'A' }, { id: 3, name: 'C' } ]
```
这个 `filterObjects` 函数会返回一个新的对象数组,其中只包含那些其指定属性 `propName` 的值不在 `excludeArray` 中的对象。
阅读全文