猿记录

一个记录、分享的博客

您的位置:主页 > 技术专栏 > javascript >

还在用for循环你就out了

2017-02-13 16:44:40 作者:yxl 次阅读 javascript

不知道从什么时候开始,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;
})

看上去确实很厉害的样子,同学们赶紧get起来,我们一起远离for循环 .- -

凡本站注明“本站”或“投稿”的所有文章,版权均属于本站或投稿人,未经本站授权不得转载、摘编或利用其它方式使用上述作品。

编辑:yxl 关键词: javascript
0

网友评论