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() 返回新数组;
相关推荐
江沉晚呤时4 分钟前
.NET Core 中 Swagger 配置详解:常用配置与实战技巧
前端·.netcore
waterHBO18 分钟前
chrome 浏览器插件 myTools, 日常小工具。
前端·chrome
哎呦你好21 分钟前
HTML 颜色全解析:从命名规则到 RGBA/HSL 值,附透明度设置与场景应用指南
前端·css·html
多云的夏天1 小时前
前端:VUE-(0)-环境搭建和helloworld
前端·javascript·vue.js
Dontla1 小时前
BootCDN介绍(Bootstrap主导的前端开源项目免费CDN加速服务)
前端·开源·bootstrap
开开心心就好1 小时前
Word图片格式调整与转换工具
java·javascript·spring·eclipse·pdf·word·excel
Stringzhua1 小时前
JavaScript【5】DOM模型
开发语言·javascript·ecmascript
90后小陈老师1 小时前
WebXR教学 07 项目5 贪吃蛇小游戏
前端·数码相机
一口一个橘子1 小时前
[ctfshow web入门] web118
前端·web安全·网络安全
GanGuaGua2 小时前
Vue3:脚手架
前端·javascript·css·vue.js·vue