时间:2021-05-26
最近工作中经常涉及到数据的处理,数组尤其常见,经常需要对其进行遍历、转换操作,网上的文章零零散散,不得已自己又找出红宝书来翻出来看,顺便记一笔,便于以后查询。
数组常用的迭代方法
ECMAScript5为数组定义了5个迭代方法。每个方法都接受两个参数:要在每一项上运行的函数fn和(可选的)运行该函数的作用域对象——影响 `this` 的值。
传入这些方法中的函数(fn)会接收3个参数:item 、index 、array; 如:
array.forEach(function(item,index,array){ //do your staff here;},this)根据使用方法的不同,这个函数执行后的返回值,可能会/不会影响方法中的返回值。
这5个迭代方法作用及返回值概览如下:
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为单位的数据
var a,b,c;var your=9000;var salaries=[8500,12000,9900,9000]; a=slaries.some(function(item,index,array){ return item<9000});console.log(a);//true;恭喜你,还有人比你工资更低b=salaries.filter(function(item,index,array){ return item== your;})console.log(b);//[9000] 呵呵,有人跟你待遇一样c=salaries.every(function(item,index,array){ return item==your; });console.log(c);//false .不是所有人都和你一样待遇哦d=salaries.map(function(item,index,array){ return item/1000 });console.log(d);//[8.5,12,9.9,9]以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文为大家介绍了javaScript数组迭代方法,供大家参考,具体内容如下每个方法都接收两个参数:要在每一项上运行的函数和(可选的)运行该函数的作用域对象。传入
本文实例讲述了JavaScript数组迭代器用法。分享给大家供大家参考。具体如下:这里注意:如果数组中有0、false、""、null、NaN迭代器将会停止fu
本文实例讲述了javascript迭代的方法。分享给大家供大家参考。具体实现方法如下:复制代码代码如下://filter()利用指定的函数确定是否返回数组中包涵
迭代方法在Javascript中迭代方法个人觉得尤为重要,在很多时候都会有实际上的需求,javascript提供了5个迭代方法来供我们操作,它们分别为:ever
本文实例讲述了JS的数组迭代方法。分享给大家供大家参考。具体实现方法如下:js数组迭代vararr1=[1,2,3,4,5,6];functiondouble(