告别for循环!


不知道从什么时候开始,for循环成为了菜鸟标配。

今天被leader发现代码里面一堆for循环让他一阵无语,好吧,老老实实的把ES5里面那些高大上的遍历函数都总结一一下吧,发誓以后再也不用for循环了 - -.

在《javascript高级编程中》,给我们介绍了几个非常重要的迭代函数,如果有这本书的同学可以去回顾一下,今天主要总结几个常常在高手们代码中看到的几个方法。

一、map

map函数可以用来遍历数组。它支持一个回调函数作为它的参数,回调函数中有三个参数,依次表示被遍历素组每一项的值value,每一项的索引index,以及数组本身

var arr = [1, 2, 3, 5];
arr.map(function(value, key, arr) {
    ...
})

我们可以对每一项元素进行处理,返回处理之后的结果并组成一个新的数组,不修改数组本身。下面的两个例子,注意return的不同

[2, 3, 4, 5].map(function(val, key) {
    return val > 3;
})

// 运行结果
[false, false, true, true]
[2, 3, 4, 5].map(function(val, key) {
    return val - 1;
})

// 运行结果
[1, 2, 3, 4]

所以聪明的你,应该也只到下面例子中的data被改变成什么样子了吧

var data = [
    {
        name: 'tom',
        age: 22
    },
    {
        name: 'link',
        age: 19
    }
]

data.map(function(item, index) {
    return item.age += 20
})

console.log(data);

二、filter

过滤函数。返回符合条件的项,最后结果由这些符合条件的项组成。参数情况与map一致。该方法不改变数组本身,运行结果会返回一个新的数组。

arr = [2, 3, 4, 5, 6].filter(function(item, index) {
    return item > 2;
})

// 运行结果
arr: [3, 4, 5, 6]

下面一个例子,返回岁数小于26岁的人。

var person = [
    {
        name: 'tom',
        age: 20,
    },
    {
        name: 'jake',
        age: 25
    },
    {
        name: 'bis',
        age: 32
    },
    {
        name: 'alex',
        age: 28
    }
]

var aaa = person.filter(function(item, index) {
    return item.age < 26
})

console.log(person, aaa);

凡是你需要从一个数组中找到一组具有某些特征或者不需要某些特征的项,你就可以用到filter过滤函数

三、reduce

我们先来看看一个实例。

var arr = [2, 3, 4, 5, 6];

var res = arr.reduce(function(res, cur, index, arr) {
    return res + cur
})

console.log(arr, res);

// res为 20 所有项的和

该方法的回调函数中有4个参数,分别是,上一项叠加后的结果,当前项,当前项的索引值,数组本身。没错,这就是一个叠加函数,通过reduce,我们可以得到某种聚合的结果,比如下面的例子,我们计算所有物品的总和

var thing = [
    {
        name: 'xiaom',
        price: 1999
    },
    {
        name: 'apple',
        price: 6666,
    },
    {
        name: 'huawei',
        price: 2999
    }
]

var acount = thing.reduce(function(res, cur) {
    return cur.price + res
}, 0)

console.log(acount);

四、 sort

排序函数。一个素组,从小到大排序应该如何做?

var arr = [2, 6, 3, 9, 1, 6];

arr.sort(function(cur, nex) {
    return cur - nex
})

console.log(arr); 
// [1, 2, 3, 6, 6, 9]

从小到大?

var arr = [2, 6, 3, 9, 1, 6];

arr.sort(function(cur, nex) {
    return nex - cur
})

将下列商品按照价格排序?

var produts = [
    {
        name: 'xssg',
        price: 10,
    },
    {
        name: 'xssg',
        price: 20,
    },
    {
        name: 'xssg',
        price: 8,
    },
    {
        name: 'xssg',
        price: 4,
    },
    {
        name: 'xssg',
        price: 7,
    },
    {
        name: 'xssg',
        price: 1,
    }
]

试试看运行结果

produts.sort(function(cur, nex) {
    return cur.price - nex.price;
})

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值