Array 功能方法

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() 返回新数组;
相关推荐
烂蜻蜓36 分钟前
HTML 表格的详细介绍与应用
开发语言·前端·css·html·html5
圣京都2 小时前
react和vue 基础使用对比
javascript·vue.js·react.js
returnShitBoy2 小时前
前端面试:axios 是否可以取消请求?
前端
u0103754562 小时前
fiddler+雷电模拟器(安卓9)+https配置
前端·测试工具·fiddler
海上彼尚2 小时前
Vue3中全局使用Sass变量方法
前端·css·sass
ᥬ 小月亮3 小时前
TypeScript基础
前端·javascript·typescript
鱼樱前端3 小时前
Vue3+TS 视频播放器组件封装(Video.js + Hls.js 最佳组合)
前端·javascript·vue.js
烛阴3 小时前
JavaScript 函数进阶之:Rest 参数与 Spread 语法(二)
前端·javascript
GISer_Jing3 小时前
ES6回顾:闭包->(优点:实现工厂函数、记忆化和异步实现)、(应用场景:Promise的then与catch的回调、async/await、柯里化函数)
前端·ecmascript·es6
天天向上10243 小时前
vue项目清理node_modules缓存
前端·vue.js·缓存