js中array的迭代方法

ES5为数组定义了五个迭代方法。每个方法都接受两个参数,要在每一项上运行的函数和(非必传)运行该函数的作用域对象。运行的函数上接受三个参数:数组项的值、该项在数组中的位置和数组对象的本身。

  1. every()
    对数组的每一项的执行给定的函数,如果该函数的每一次返回值都是true,则every函数返回true。
var numbers = [1,2,3,4,5,4,3,2,1];
var everyResult = numbers.every(function(item,index,array)){
	return (item > 2);
}
alert (everyResult); //false
  1. filter()
    对数组中的每一项执行给定的函数,filter()函数返回入参函数的返回值为true的项组成的新数组。
var numbers = [1,2,3,4,5,4,3,2,1];
var filterResult = numbers.filter(function(item,index,array)){
	return (item > 2);
}
alert (everyResult); // [3,4,5,4,3]
  1. forEach()
    对数组中的每一项执行给定的函数,forEach()函数没有返回值。
var numbers = [1,2,3,4,5,4,3,2,1];
numbers.forEach(function(item,index,array)){
	//执行某些操作	
}
  1. map()
    对数组中的每一项运行给定的函数,返回每次函数调用的结果组成的数组。
var numbers = [1,2,3,4,5,4,3,2,1];
var mapResult = numbers.map(function(item,index,array)){
	return  item *2;
}
alert (mapResult); // [2,4,6,8,10,8,6,4,2]
  1. some()
    对数组中的每一项运行给定函数,如果该函数对任一项返回true,则返回true。
var numbers = [1,2,3,4,5,4,3,2,1];
var someResult = numbers.some(function(item,index,array)){
	return (item > 2);
}
alert (someResult); //true
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章