JavaScript数组迭代方法


Posted in Javascript onMarch 03, 2017

最近工作中经常涉及到数据的处理,数组尤其常见,经常需要对其进行遍历、转换操作,网上的文章零零散散,不得已自己又找出红宝书来翻出来看,顺便记一笔,便于以后查询。

数组常用的迭代方法

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]

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
二行代码解决全部网页木马
Mar 28 Javascript
javascript tips提示框组件实现代码
Nov 19 Javascript
前后台交互过程中json格式如何解析以及如何生成
Dec 26 Javascript
javascript中this做事件参数相关问题解答
Mar 17 Javascript
JavaScript栏目列表隐藏/显示简单实现
Apr 03 Javascript
JavaScript中的关键字&quot;VAR&quot;使用详解 分享
Jul 31 Javascript
json数据与字符串的相互转化示例
Sep 18 Javascript
javascript表格隔行变色加鼠标移入移出及点击效果的方法
Apr 10 Javascript
jQuery实现鼠标选文字发新浪微博的方法
Apr 02 Javascript
浅谈AngularJS中ng-class的使用方法
Nov 11 Javascript
vue.js入门(3)——详解组件通信
Dec 02 Javascript
详解js中let与var声明变量的区别
Apr 05 Javascript
vue.js的提示组件
Mar 02 #Javascript
js实现功能比较全面的全选和多选
Mar 02 #Javascript
jQuery实现三级联动效果
Mar 02 #Javascript
Spring Boot+AngularJS+BootStrap实现进度条示例代码
Mar 02 #Javascript
纯js仿淘宝京东商品放大镜功能
Mar 02 #Javascript
JSONP跨域请求
Mar 02 #Javascript
jquery easyui dataGrid动态改变排序字段名的方法
Mar 02 #Javascript
You might like
mysql总结之explain
2012/02/27 PHP
php使用标签替换的方式生成静态页面
2015/05/21 PHP
php文件上传的两种实现方法
2016/04/04 PHP
浅析Yii2 gridview实现批量删除教程
2016/04/22 PHP
PHP递归算法的简单实例
2019/02/28 PHP
微信支付之JSAPI公众号支付详解
2019/05/15 PHP
PHP实现倒计时功能
2020/11/16 PHP
window.location.hash 使用说明
2010/11/08 Javascript
jquery弹出框的用法示例(一)
2013/08/26 Javascript
smartcrop.js智能图片裁剪库
2015/10/14 Javascript
Jquery实现仿京东商城省市联动菜单
2015/11/19 Javascript
JS Attribute属性操作详解
2016/05/19 Javascript
浅谈js中test()函数在正则中的使用
2016/08/19 Javascript
jQuery弹出遮罩层效果完整示例
2016/09/13 Javascript
js仿支付宝多方框输入支付密码效果
2016/09/27 Javascript
在iframe中使bootstrap的模态框在父页面弹出问题
2017/08/07 Javascript
vue-resouce设置请求头的三种方法
2017/09/12 Javascript
webpack4的迁移的使用方法
2018/05/25 Javascript
vue-router为激活的路由设置样式操作
2020/07/18 Javascript
解决vue项目运行npm run serve报错的问题
2020/10/26 Javascript
[57:37]EG vs Mineski 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
python通过imaplib模块读取gmail里邮件的方法
2015/05/08 Python
解决Django模板无法使用perms变量问题的方法
2017/09/10 Python
python中如何使用正则表达式的集合字符示例
2017/10/09 Python
在Pycharm中调试Django项目程序的操作方法
2019/07/17 Python
Django框架教程之中间件MiddleWare浅析
2019/12/29 Python
解决PyCharm无法使用lxml库的问题(图解)
2020/12/22 Python
美赞臣营养马来西亚旗舰店:Enfagrow马来西亚
2019/07/26 全球购物
vue路由实现登录拦截
2021/03/24 Vue.js
小学生新年寄语
2014/04/03 职场文书
广告业务员岗位职责
2015/02/13 职场文书
军训决心书范文
2015/09/22 职场文书
2016年党员承诺书范文
2016/03/24 职场文书
php 解析非标准json、非规范json
2021/04/01 PHP
CSS3 实现NES游戏机的示例代码
2021/04/21 HTML / CSS
Golang gRPC HTTP协议转换示例
2022/06/16 Golang