昨天我们有提到说for-of和forEach可以用来处理数组,但其实还有很多方法可以更快速及精简代码的达到你要的效果。

话不多说,我们赶紧来看吧!

Array.prototype.map()

会回传一个新数组,其值为原数组每一个值经回呼函式运算后的回传值。故新数组长度会与原数组相同。

要注意的是,如果没有回传值,会预设回传undefined。

var arr = [1,2,3,4,5,6,7,8,9];

var arrMap = arr.map((item,index,array)=>{

return item * index

})

console.log(arrMap);//[0,2,6,12,20,30,42,56,72]

map最常拿来与for和for-in作比较,有人认为我用原本的循环就可以达成了,为何还要用map呢?

那我们来比较一下两者吧:

var arr = [1,2,3,4,5,6,7,8,9];

var arrMap = arr.map((item,index,array)=>{

return item * index

})

var arrFor = [];

for(let i = 0;i < arr.length;i++){

arrFor.push(arr[i]*i)

}

虽然意思都是一样,但是今天别人看到你写for时需要思考说,这个for是在干嘛?有改动什么东西吗?

但如果是map别人一看就知道说,这是对原数组作操作并回传一个新的(cctsol)。

Array.prototype.filter()

会回传一个数组,其值为原数组每一个值经回呼函式运算后回传为true的值,故长度不一定等于原数组。

var arr = [1,2,3,4,5,6,7,8,9];

var arrFilter = arr.filter((item,index,array)=>{

return item%2 === 0;

});

console.log(arrFilter);//[2,4,6,8]

通常用于条件过滤,所以才叫做filter(过滤)。

像是过滤出不重复的数组:

var arr = ['Jason','Turtle','Chris','Jason','Kai','Chris','Henry','Kai'];

var uniquePerson = arr.filter((item,index,array)=>{

return array.indexOf(item)=== index;

});

console.log(uniquePerson);//[“Jason”,“Turtle”,“Chris”,“Kai”,“Henry”]

Array.prototype.find()

会回传第一个满足函式条件的值,否则回传undefined。

var arr = ['Jason','Turtle','Chris','Jason','Kai','Chris','Henry','Kai'];

var findPerson = arr.find((item,index,array)=>{

return item === 'Chris';

});

console.log(findPerson);

Array.prototype.every()

会回传数组是否每一个值都满足函式的条件。

var arr = [{

name:“Jason”,

age: 29

},

{

name:“Chris”,

age: 31

},

{

name:“Kai”,

age: 24

},

{

name:“Henry”,

age: 24

}

];

var checkAge = arr.every((item,index,array)=>{

return item.age > 10;

});

console.log(checkAge);//true

var test = arr.every((item,index,array)=>{

return item.age < 30;

});

console.log(test);//false

Array.prototype.some()

跟every用法很像,差别在于只要部分符合及回传true。

var arr = [{

name:“Jason”,

age: 29

},

{

name:“Chris”,

age: 31

},

{

name:“Kai”,

age: 24

},

{

name:“Henry”,

age: 24

}

];

var test = arr.some((item,index,array)=>{

return item.age < 30;

});

console.log(test);//true

Array.prototype.reduce()

会将数组内每一个值经回呼函式运算后回传单一个值。

这个方法很特别的是每一次呼叫可以跟前一个回传值作再次运算并回传。

accumulator用来累积回呼函式回传值的累加器,是上一次呼叫后,所回传的累加数值。

currentValue是当前数组的值

currentIndex当前数组值的索引(可选)

array原本的数组(可选)

var arr = [1,2,3,4,5,6,7,8,9,10];

var sum = arr.reduce((accumulator,item)=>{

return accumulator + item;

});

console.log(sum);

在这边要注意到reduce有个很特别的参数initialValue初始值,若没有提供初始值,原数组的第一个元素将会被当作初始的累加器。

var arr = [1,2,3,4,5,6,7,8,9,10];

var sum = arr.reduce((accumulator,item)=>{

console.count(accumulator,item);

return accumulator + item;

},0);

console.log(sum);

可以跟上一个例子作比较,会发现没有提供initialValue,会少运算一次喔(aichi-kaigo)!

以上是今天的数组常见处理方法,下次要对数组作操作时不要一开始就用for,试着用这先简单明了的方法吧!

学JS的心路历程 -数组常见处理方法的更多相关文章

  1. 学JS的心路历程-for of和for in

    我们在刚入门JS时候,说到要跑出数组的每个值肯定都是这样子: var arr = [1,2,3,4,5,6]: for(let i = 0:i < arr.length:i++){ consol ...

  2. 学JS的心路历程-正规表达式Regular Expression

    今天我们来看正规表达式,在谈到为什么需要多学这个之前,先来看个示例. 假设需要判断输入字串是否含有“apple”: var text=“A apple a day keeps the doctor a ...

  3. 学JS的心路历程Day26 - PixiJS -入坑

    后来知道也可以透过canvas让网页动起来! 而PixiJS是使用WebGL在canvas上绘制内容与制作动态 且同时有下列特色: 支持多点触控 掩码与混合模式 可外加WebGL滤镜 多装置支持 等等 ...

  4. 学JS的心路历程 -物件与原型(二)

    昨天有提到说Object.setPrototypeOf可以指定一个物件为另一个物件的原型,但有想过到底这个原型,也就是[[Prototype]]最终会到何处吗? 答案是Object.prototype ...

  5. 学JS的心路历程-Promise(三)

    今天我们来说then一些特殊情况以及Promise.all()与Promise.race(). 我们都知道函式作为参数传入时,可以参照的方式传入,也能传入时执行拿回传值作使用: function us ...

  6. 学JS的心路历程 -函式(三)this

    this是什么,取决于被呼叫的呼叫地点. 昨天有提到说,呼叫函式时候会传递隐含参数:arguments和this并讲解了arguments,今天我们就来探讨this吧! 什么是this 我们都会呼叫函 ...

  7. 学JS的心路历程-函式(二)arguments

    参数(argument)与函式参数(parameter) 在讨论函式时,很多人都会把这两个搞混,我自己也不例外. 虽然讲错别人也听得懂,但是我们还是要搞清楚这两个的定义到底是什么! 参数是当我们呼叫函 ...

  8. 学JS的心路历程 - JS应用

    各家电商网站都推出了各种活动和现今优惠券,当时在逛PTT时看到了有篇文章,提供代码教大家用JS的方式抢票,看了一下后发现好像很多人好奇这是怎么做的,于是就想说想一篇文章来讲解一下. 我们先来看一下折价 ...

  9. 学JS的心路历程Day28 - PixiJS -基础(二)

    材质暂存(texture cache) 昨天有说到,图片要放入stage前,需要先把图片转成Sprite的特殊图片物件. 但是我们也可以先将图片放进材质暂存(texture cache). 什么是「材 ...

随机推荐

  1. vs2015 引用lib库和dll

    1.首先右键项目->属性 2.在项目中添加lib文件夹,把lib库放在文件夹下面,然后在图中的库目录引用当前路径的lib文件夹 3.在项目的路径下添加include中添加头文件,然后在常规中添加 ...

  2. 快速部署MySQL数据库

    一.下载对应的软件版本 下载地址:http://mirrors.sohu.com/mysql/MySQL-5.6/ [root@localhost ~]# wget -q http://mirrors ...

  3. C#winform抓取百度,Google搜索关键词结果

    基于网站seo,做了一采集百度和Google搜索关键字结果的采集.在这里与大家分享一下 先看先效果图 代码附加:  1   private void baidu_Click(object sender ...

  4. day5--装饰器函数的信息打印,迭代器,生成器,列表推导式,内置函数

    本文档主要内容: 一 装饰器函数的信息打印 二 迭代器 三 生成器 四 生成器表达式和列表推导式 五 内置函数 一 装饰器函数的信息打印 一个函数一旦被装饰器给装饰后,这个函数的信息使用原来的命令打印 ...

  5. android 开发 实现多个动态权限的方法(并且兼容6.0以下的版本权限授权)

    android开发权限授权因为版本的不同有不同的授权方式,6.0以下的版本使用的是在注册表中添加权限的静态授权(这种授权权限提示只会出现在app安装的时候),而6.0以上(包含6.0)就需要动态授权的 ...

  6. docker unbuntu 32-bit 更新apt-get

    1.vi /etc/apt/sources.list deb http://mirrors.aliyun.com/debian wheezy main contrib non-free deb-src ...

  7. spring mvc 跨域问题。。。解决

    官方推荐方式: http://spring.io/blog/2015/06/08/cors-support-in-spring-framework 方式1: $.ajax({ //前台:常规写法.注意 ...

  8. 《算法》BEYOND 部分程序 part 3

    ▶ 书中第六章部分程序,加上自己补充的代码,包括 Graham 扫描生成凸包,计算最远点对 ● Graham 扫描生成凸包 package package01; import java.util.Ar ...

  9. django之Q

    def _add_q(self, q_object, used_aliases, branch_negated=False, current_negated=False, allow_joins=Tr ...

  10. Oracle事务隔离级别

    转自:https://blog.csdn.net/leozhou13/article/details/50449965