微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javaScript数组迭代方法详解

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

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

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

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

请看以下例子:

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

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

<div class="jb51code">
<pre class="brush:js;">
var arr = [3,7,"a"];

var isNum = function(elem,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,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数组迭代方法有所帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐