数组迭代方法:
ECMAScript 5 为数组定义了 5 个迭代方法。每个方法都接收两个参数:要在每一项上运行的函数和(可选的)运行该函数的作用域对象——影响 this 的值。传入这些方法中的函数会接收三个参数:数组项的值、该项在数组中的位置和数组对象本身。根据使用的方法不同,这个函数执行后的返回值可能会也可能不会影响方法的返回值。以下是这 5 个迭代方法的作用。
every() :对数组中的每一项运行给定函数,如果该函数对每一项都返回 true ,则返回 true 。
filter() :对数组中的每一项运行给定函数,返回该函数会返回 true 的项组成的数组。
forEach() :对数组中的每一项运行给定函数。这个方法没有返回值。
map() :对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组。
some() :对数组中的每一项运行给定函数,如果该函数对任一项返回 true ,则返回 true 。
以上方法都不会修改数组中的包含的值。
在这些方法中,最相似的是 every() 和 some() ,它们都用于查询数组中的项是否满足某个条件。
对 every() 来说,传入的函数必须对每一项都返回 true ,这个方法才返回 true ;否则,它就返回
false 。而 some() 方法则是只要传入的函数对数组中的某一项返回 true ,就会返回 true 。
console.log('数组函数的操作');
var arr = ['21', 'yangyulong', new Object(), [1,2,3]];
console.log('使用every函数');
var everyResulr = arr.every(function(item, index, array){
// console.log(item, index, array);
// return item > 2;
return true;
});
console.log(everyResulr);
console.log('++++++++++++++数组的filter函数使用+++++++++++++++++++++++++++++');
var filterArr = arr.filter(function(item, index, array){
return typeof item == 'object' ? true : false;
});
console.log(filterArr);
console.log('===============数组map函数的使用======================');
var mapArr = arr.map(function(item){
return item + 100;
});
console.log(mapArr)