为了账号安全,请及时绑定邮箱和手机立即绑定

5个很实用的数组迭代方法

标签:
JavaScript

学习数组迭代方法

  • every() 迭代数组每一项,每项都符合条件的才返回true,反之false
  • some() 迭代数组每一项,只要有一项符合条件就返回true,如果全部不符合才返回false
  • map() 迭代数组每一项,可以给特定条件会返回重新组成新的数组
  • filter() 迭代数组每一项,可以给特定的条件进行筛选返回新的数组
  • forEach() 迭代数组每一项,没有返回值

every()

every() 方法,对数组中的每一项进行迭代,如果每一项都符合条件才可以返回true,反之返回false。

情景: 有五个孩子,如果这个五个孩子都大于或等于18岁,才能进入此网站

代码示例:

let children = [
    {name: 'Bob', age: 18},
    {name: 'Peter', age: 16},
    {name: 'Lynn', age: 28},
    {name: 'Jack', age: 38}
]

// // 数组中需要每一个项都符合条件才返回true,反之返回false
let isAdults = children.every(child => child.age >= 18)
console.log(isAdults); // false 因为Peter的age小于18岁

// 手动把Peter的age改为20,再进行测试
children[1].age = 20;
let isAdults2 = children.every(child => child.age >= 18)
console.log(isAdults2); // true 所有的孩子都已经满足大于或者等于18岁了,所以返回true

some()

some() 方法,对数组的每一项迭代,只有一个选项符合条件的,就可以返回true了,只有全部不符合条件才返回false。

情景: 如果有4个人,其中只有一个小妹妹就可以通过了

代码示例:

let people = [
    {name: 'Bob', sex: 'boy'},
    {name: 'Peter', sex: 'boy'},
    {name: 'Lynn', sex: 'girl'},
    {name: 'Jack', sex: 'boy'}
]

// 数组中只需要符合一个条件就返回true,反之返回false
let hasGirl = people.some(val => val.sex === 'girl');
console.log(hasGirl) // true

map()

map() 方法,对数组的每一项迭代,给特定的条件返回重新组成数组。

情景: 有五个员工,突然当月老板给每个人发奖金1w,求每个人的当月发的工资为多少

代码示例:

let employees = [
    {name: 'Bob', wage: 5000},
    {name: 'Peter', wage: 10000},
    {name: 'Lynn', wage: 15000},
    {name: 'Jack', wage: 20000}
]

// 对每个员工进行加薪10000元奖金,返回新数组
let employeesWage = employees.map(item => {
    return {
        name: item.name,
        // 每个人加1000元
        wage: item.wage + 10000
    }
});
console.log(employeesWage);

/**
 * 返回了新的员工工资数组
 * [
 *   { name: 'Bob', wage: 15000 },
 *   { name: 'Peter', wage: 20000 },
 *   { name: 'Lynn', wage: 25000 },
 *   { name: 'Jack', wage: 30000 }
 * ]
 **/

filter()

filter() 方法,对数组的每一项迭代,根据给出的条件进行筛选且返回新数组

情景: 筛选班上期末考试成绩大于或等于90分的学生

代码示例:

let students = [
    {name: 'Bob', grade: 100},
    {name: 'Peter', grade: 75},
    {name: 'Lynn', grade: 80},
    {name: 'Jack', grade: 95}
]

// 获得成绩大于或等于90的学生,返回新数组
let awardStudents = students.filter(val => val.grade >= 90);
console.log(awardStudents)
/**
 * 输出新数组:
 * [
 *   { name: 'Bob', grade: 100 },
 *   { name: 'Jack', grade: 95 }
 * ]
 */

forEach()

forEach() 方法,对数组的每一项迭代,没有返回值

情景: 我想看下班上的每一位同学的成绩为多少,没有返回值

代码示例:

// 读取每个人的成绩,没有返回值
students.forEach(item => {
    console.log(`${item.name}同学的成绩为${item.grade}`);
    /**
     * 输出:
     * Bob同学的成绩为100
     * Peter同学的成绩为75
     * Lynn同学的成绩为80
     * Jack同学的成绩为95
     */
})

// 获取获得奖励同学,没有返回值
awardStudents.forEach(item2 => {
    console.log(`获得奖励的同学有${item2.name}`)
    /* 输出:
     * 获得奖励的同学有Bob
     * 获得奖励的同学有Jack
     */
})

思考与总结

往往最基础的知识能最简单、快捷地解决问题,这五个迭代方法在平时非常实用,要记住这五个数组迭代方法各自的优点,在需要的情景下,能马上想到用哪个方法最简单,最快捷地实现需求。

点击查看更多内容
48人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
Web前端工程师
手记
粉丝
4318
获赞与收藏
1744

关注作者,订阅最新文章

阅读免费教程

感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消