Array 对象是前端开发中使用频率最高的数据结构之一,今天我们来复习一下它的几种操作方法。
find()
该方法返回数组中满足条件(提供的测试函数)的第一个元素的值,如果没有满足条件的值则返回 undefined。
javascript
const arr = [2,5,6,1,0];
const v1 = arr.find((item, index, that) =>{
return item > 5;
});
console.log(v1); // 6
const v2 = arr.find((item, index, that) =>{
return item < 0;
});
console.log(v2); // undefined
再看一个稍微复杂一点的例子:
javascript
const arr = [
{
name: "张三",
age: 18
},
{
name: "李四",
age: 30
},
{
name: "王五",
age: 20
}
];
const oldP = arr.find(item=> item.age > 25);
console.log(oldP); // {name: "李四", age: 30}
与 find() 方法相似的还有:findIndex()、 findLastIndex()、findLast() 等。
some()
some() 方法用来判断数组是否包含满足条件的元素,如果包含则返回 true,否则返回 false,但是不返回元素本身。
javascript
const arr = [2,5,6,1,0];
const res1 = arr.some((item, index, that) =>{
return item > 5;
});
console.log(res1); // true
const res2 = arr.some((item, index, that) =>{
return item < 0;
});
console.log(res2); // false
复杂例子:
JavaScript
const arr = [
{
name: "张三",
age: 18
},
{
name: "李四",
age: 30
},
{
name: "王五",
age: 20
}
];
const res = arr.some(item=> item.age > 25);
console.log(res); // true
filter()
filter() 方法返回所有满足条件的元素组成的新数组。
javascript
const arr = [2,5,6,1,0];
const res1 = arr.filter((item, index, that) =>{
return item > 3;
});
console.log(res1); // [5, 6]
const res2 = arr.filter((item, index, that) =>{
return item < 0;
});
console.log(res2); // []
复杂例子:
JavaScript
const arr = [
{
name: "张三",
age: 18
},
{
name: "李四",
age: 30
},
{
name: "王五",
age: 20
}
];
const res = arr.filter(item=> item.age < 25);
console.log(res); // {name: "张三", age: 18},{name: "王五", age: 20}
总结
本文的内容总结如下:
- find() 返回元素本身或 undefined;
- some() 返回判断的结果,值为 true 或 false;
- filter() 返回新数组;