JavaScript数组(2)—遍历/迭代方式 8栽

多年来做事受到常常提到到多少的处理,数组尤其常见,经常用针对那个进展遍历、转换操作,网上的篇章零零散散,不得已自己以摸有红宝书来翻译出看,顺便记一笔,便于以后查询。

– 数组常用底办法

ECMAScript5啊数组定义了8单迭代方法。每个方法都领受两独参数:要当各国一样项上运行的函数fn和(可选的)运行该函数的作用域对象——影响
`this` 的值。

流传这些措施吃之函数(fn)会收下3单参数:item 、index 、array; 如:

array.forEach(function(item,index,array){
    //do your staff here;
},this)

 

根据使用办法的两样,这个函数执行后的返值,可能会见/不会见潜移默化方法被的回值。

  这5个迭代方法作用和返回值概览如下(末尾补充另外3只):

ECMAScript5 Array元素迭代方法
方法名 方法作用  返回值
every() 针对数组中每一项元素运行指定函数 Boolean:若每一项都返回true,返回true;
filter() 针对数组中每一项元素运行指定函数, Array:   返回函数运行返回true的元素组成的新数组
forEach() 针对数组中每一项元素运行指定函数 null:  无返回值
map() 针对数组中每一项元素运行指定函数  Array:  返回函数运行后,得到到新新元素组成的新数组
some() 针对数组中每一项元素运行指定函数 Boolean: 若有任意一项执行函数后返回true, 则返回true

简单来说:

every() 、some() 方法可用来对数组元素进行标准判断;

filter()  、map() 方法可用来对数组进行标准筛选/再处理;

forEach() 方法对不针对数组本身做操作,仅仅对数组元素的次坏采取;

脚介绍下各个艺术的运栗子:

优先来借要一个光景,你拿到了店家之本月工资清单,假而你的工资吧9000;公司职工工资整合的数组为salaries=[8500,12000,9900,9000],

a. 想清楚 你的薪资是匪是最低的;

b.想知道 有没有有人与您工资一样多;

c.想知道  是休是具有人待遇都一样;

d.想      把大家之工钱还换成K为单位的数据 

 1 var a,b,c,d;
 2 var your=9000;
 3 var salaries=[8500,12000,9900,9000];
 4  a=salaries.some(function(item,index,array){
 5    return  item<9000
 6 });
 7 console.log(a);//true;恭喜你,还有人比你工资更低
 8 
 9 
10 b=salaries.filter(function(item,index,array){
11    return item== your;
12 })
13 console.log(b);//[9000] 呵呵,有人跟你待遇一样
14 
15 c=salaries.every(function(item,index,array){
16    return item==your; 
17 });
18 console.log(c);//false .不是所有人都和你一样待遇哦
19 
20 d=salaries.map(function(item,index,array){
21    return item/1000 
22 });
23 console.log(d);//[8.5,12,9.9,9]

  PS:补充三个疏漏的法

1.array.reduce(callback,[initalValue]):归并函数——对每个数组元素执行回调函数,返回最后一次调整用结果值

    //此处回调函数有4独参数,其中第4独参数可挑选;即calback(accumulator,value,index,array,initalValue)

2.Array.find(callback[,thisArg]):查找函数——返回第一只经测试的元素

3.Array.findIndex(callback[,Arg]):查找函数——返回第一个经过测试的因素的索引值

 

关押罢这些是否觉得以后还为未待for循环了,那么看看下面这个坑吧:

[1,2,3].map(parseInt);//[1,NaN,NaN]




//注意:
//1.Array.map(iterm,index,array)
//2.parseInt(value,base)