javaScript数组迭代方法详解


Posted in Javascript onApril 14, 2016

本文为大家介绍了javaScript数组迭代方法,供大家参考,具体内容如下

每个方法都接收两个参数:要在每一项上运行的函数  和  (可选的)运行该函数的作用域对象。

传入这些方法中的函数会接收三个参数:数组项的值,该项在数组中的位置,数组对象本身。

forEach()  对数组中的每一项运行 给定函数。该方法没有返回值。
every()  对数组中的每一项运行 给定函数,如果数组的每一项都返回true,则返回true。
some()  对数组中的每一项运行 给定函数,如果数组的任意一项返回true,则返回true。
fliter()  如果数组的每一项都返回true,则返回true。返回该函数会返回true的项组成的数组。
map()  如果数组的每一项都返回true,则返回true。返回每次函数调用的结果组成的数组。

请看以下例子:

var numbers = [1,2,3,4,5,4,3,2,1];
//every()
var everyResult = numbers.every(function(item, index, array){
 return (item > 2);
});
alert(everyResult); //false
//some()
var someResult = numbers.some(function(item, index, array){
 return (item > 2);
});
alert(someResult); //true
//filter()
var filterResult = numbers.filter(function(item, index, array){
 return (item > 2);
});
alert(filterResult); //[3,4,5,4,3]
//map()
var mapResult = numbers.map(function(item, index, array){
 return (item * 2);
});
alert(mapResult); //[2,4,6,8,10,8,6,4,2]
//forEach()
numbers.forEach(function(item, index, array){
 alert(item);
}); //多个弹窗分别显示数组中的元素

另一个javaScript数组迭代方法,如下

var arr = [3,4,5,6,7,"a"];

var isNum = function(elem,index,AAA){
return !isNaN(elem);
}

var toUpperCase = function(elem){
return String.prototype.toUpperCase.apply(elem);
}

var print = function(elem,index){
console.log(index+"."+elem);
}

/*对数组中的每一项执行测试函数,直到获得对指定的函数返回 false 的项。 使用此方法 可确定数组中的所有项是否满足某一条件,类似于&&的含义*/
var res = arr.every(isNum);
console.log(res);//false;

/*对数组中的每一项执行测试函数,直到获得返回 true 的项。 使用此方法确定数组中的所有项是否满足条件.类似于||的含义*/
res = arr.some(isNum);
console.log(res);//true

/*对数组中的每一项执行测试函数,并构造一个新数组,返回 true的项被添加进新数组。 如果某项返回 false,则新数组中将不包含此项*/
res = arr.filter(isNum);
console.log(res);//[3, 4, 5, 6, 7]

/*对数组中的每一项执行函数并构造一个新数组,并将原始数组中的每一项的函数结添加进新数组。*/
res = arr.map(toUpperCase);
console.log(res);//["3", "4", "5", "6", "7", "A"]

/*对数组中的每一项执行函数,不返回值*/
res = arr.forEach(print);
console.log(res);

 

 

//自己扩展

/*Array.prototype.every = function(fun,obj) {
var len = this.length;
if (typeof fun != "function")
throw new TypeError();
for (var i = 0; i < len; i++) {
if (!fun.call(obj,this[i], i,this))
return false;
}
return true;
};*/

以上就是本文的全部内容,希望对大家学习javaScript数组迭代方法有所帮助。

Javascript 相关文章推荐
jQuery ajax BUG:object doesn't support this property or method
Jul 06 Javascript
jQuery使用zTree插件实现树形菜单和异步加载
Feb 25 Javascript
Bootstrap的基本应用要点浅析
Dec 19 Javascript
jquery实现百叶窗效果
Jan 12 Javascript
详解Angular-Cli中引用第三方库
May 21 Javascript
javascript 开发之网页兼容各种浏览器
Sep 28 Javascript
Bootstrap table使用方法汇总
Nov 17 Javascript
vue2实现数据请求显示loading图
Nov 28 Javascript
Vue-Router2.X多种路由实现方式总结
Feb 09 Javascript
Vue-CLI 3 scp2自动部署项目至服务器的方法
Jul 24 Javascript
vue-以文件流-blob-的形式-下载-导出文件操作
Aug 07 Javascript
vue3.0自定义指令(drectives)知识点总结
Dec 27 Vue.js
基于JS实现移动端访问PC端页面时跳转到对应的移动端网页
Dec 24 #Javascript
js贪吃蛇游戏实现思路和源码
Apr 14 #Javascript
JS跨域解决方案之使用CORS实现跨域
Apr 14 #Javascript
[原创]Bootstrap 中下拉菜单修改成鼠标悬停直接显示
Apr 14 #Javascript
Seajs 简易文档 提供简单、极致的模块化开发体验
Apr 13 #Javascript
原生js编写autoComplete插件
Apr 13 #Javascript
JS中的eval 为什么加括号
Apr 13 #Javascript
You might like
深入了解php4(2)--重访过去
2006/10/09 PHP
php小技巧之过滤ascii控制字符
2014/05/14 PHP
PHP微信红包API接口
2015/12/05 PHP
PHP中explode函数和split函数的区别小结
2016/08/24 PHP
使用Apache的rewrite
2021/03/09 Servers
json 实例详细说明教程
2009/10/31 Javascript
$.getJSON在IE下失效的原因分析及解决方法
2013/06/16 Javascript
详解JavaScript语法对{}处理的坑爹之处
2014/06/05 Javascript
js中一维数组和二位数组中的几个问题示例说明
2014/07/17 Javascript
jQuery实现MSN中文网滑动Tab菜单效果代码
2015/09/09 Javascript
CSS3 media queries结合jQuery实现响应式导航
2016/09/30 Javascript
利用NPM淘宝的node.js镜像加速nvm
2017/03/27 Javascript
Vue生命周期示例详解
2017/04/12 Javascript
JS实现上传图片实时预览功能
2017/05/22 Javascript
js实现音乐播放控制条
2017/09/09 Javascript
详解vue-admin和后端(flask)分离结合的例子
2018/02/12 Javascript
layer弹出层显示在top顶层的方法
2019/09/11 Javascript
RxJS在TypeScript中的简单使用详解
2020/04/13 Javascript
写给新手同学的vuex快速上手指北小结
2020/04/14 Javascript
Vue.js原理分析之nextTick实现详解
2020/09/07 Javascript
vue+element table表格实现动态列筛选的示例代码
2021/01/14 Vue.js
Python获取当前路径实现代码
2017/05/08 Python
基于Python解密仿射密码
2019/10/21 Python
Python操作注册表详细步骤介绍
2020/02/05 Python
django model通过字典更新数据实例
2020/04/01 Python
CSS3 rgb and rgba(透明色)的使用详解
2020/09/25 HTML / CSS
日本最大级玩偶手办购物:あみあみ Amiami
2018/04/23 全球购物
Solid & Striped官网:美国泳装品牌
2019/06/19 全球购物
STP的判定过程
2012/10/01 面试题
中学教师管理制度
2014/01/14 职场文书
矿泉水广告词
2014/03/20 职场文书
小学教师读书活动总结
2014/07/08 职场文书
2014年高数考试作弊检讨书
2014/12/14 职场文书
军训通讯稿范文
2015/07/18 职场文书
朋友圈早安励志语录!
2019/07/08 职场文书
5种 JavaScript 方式实现数组扁平化
2021/10/05 Javascript