淺談javascript 迭代方法
ECMAScript5為數(shù)組定義了5個迭代方法。每個方法都接收兩個參數(shù):要在每一項上運行的函數(shù)和(可選的)運行該函數(shù)的作用域?qū)ο螅从绊憈his的值)。傳入這些方法中的函數(shù)會接收三個參數(shù):數(shù)組項的值、該項在數(shù)組中的位置和數(shù)組對象本身。根據(jù)使用方法的不同,這個函數(shù)執(zhí)行后的返回值可能會也可能不會影響方法的返回值。這5個迭代方法是:
五個迭代方法 都接受兩個參數(shù):要在每一項上運行的函數(shù) 和 運行該函數(shù)的作用域(可選)
every():對數(shù)組中的每一項運行給定函數(shù)。如果函數(shù)對每一項都返回true,則返回true。
filter():對數(shù)組中的每一項運行給定函數(shù)。返回該函數(shù)會返回true的項組成的數(shù)組。
forEach():對數(shù)組中每一項運行給定函數(shù)。該函數(shù)沒有返回值。
map():對數(shù)組中每一項運行給定函數(shù)。返回每次函數(shù)調(diào)用的結(jié)果組成的函數(shù)。
some():對數(shù)組中每一項運行給定函數(shù)。如果函數(shù)對 任一項返回true,則返回true
以上所有的方法都不會修改數(shù)組中包含的值。
在上面的方法中,every()和some()非常相似,它們都用于查詢數(shù)組中的項是否滿足某個條件。對于every()方法來說,傳入的函數(shù)必須對每一項都返回true,這個方法才返回true。否則,它就返回false。而some()方法則是只要傳入的函數(shù)對數(shù)組的某一項返回true,就會返回true。例如:
var nums = [1,2,3,4,5,4,3,2,1];
var result = nums.every(function(item, index, array){
return (item > 2);
})
console.info(result);
上面的代碼會在控制臺中打印false。
var nums = [1,2,3,4,5,4,3,2,1];
var result = nums.some(function(item, index, array){
return (item > 2);
})
console.info(result);
上面的代碼會在控制臺中打印true。
下面是一個filter()函數(shù)的例子,它利用指定的函數(shù)確定是否存在返回的數(shù)組中包含某一項。例如,要返回一個所有數(shù)值都大于2的數(shù)組,可以使用下面的代碼:
var nums = [1,2,3,4,5,4,3,2,1];
var result = nums.filter(function(item, index, array){
return (item > 2);
})
console.info(result); // [3,4,5,4,3]
上面的代碼通過調(diào)用filter()方法返回包含3,4,5,4,3的數(shù)組。這個方法對于查詢符合某些條件的所有數(shù)組非常有用。
map()方法也返回一個數(shù)組,而這個數(shù)組的每一項都是在原始數(shù)組中的對應(yīng)項上運行傳入函數(shù)的結(jié)果。例如,可以給數(shù)組中的每一項都乘以2,然后返回這些乘積組成的數(shù)組:
var nums = [1,2,3,4,5,4,3,2,1];
var result = nums.map(function(item, index, array){
return item * 2;
})
console.info(result); // [2,4,6,8,10,8,6,4,2]
map()方法適合用于創(chuàng)建包含的項于另一個數(shù)組一一對應(yīng)的數(shù)組。
最后一個是forEach()方法,它只是對數(shù)組中的每一項運行傳入的函數(shù)。這個方法沒有返回值,本質(zhì)上于使用for循環(huán)迭代數(shù)組是一樣的??聪旅娴睦樱?/p>
var nums = [1,2,3,4,5,4,3,2,1];
nums.forEach(function(item, index, array){
//執(zhí)行需要的操作
})
js中的這些數(shù)組方法通過執(zhí)行不同的操作,可以大大的方便處理數(shù)組的任務(wù)。
支持這些迭代方法的瀏覽器有:IE9+,F(xiàn)irefox2+,Safari3+,Opera9.5+和Chrome。
var numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
//every()和some()最相似
//every() item:當前遍歷項,index:當前項索引,array:數(shù)組對象本身
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 本質(zhì)上和for循環(huán)沒有區(qū)別
var forEachResult=numbers.forEach(function(item,index,array){
alert(item)
});
以上就是本文的全部內(nèi)容了,希望能給大家一些提示,能夠更好的理解javascript迭代方法。
相關(guān)文章
javascript使用window.open提示“已經(jīng)計劃系統(tǒng)關(guān)機”的原因
這篇文章主要介紹了javascript使用window.open提示“已經(jīng)計劃系統(tǒng)關(guān)機”的原因,本文得出結(jié)論是安裝了系統(tǒng)更新或其它原因,要把系統(tǒng)重啟時才會提示這個問題,所以,遇到這個問題,重啟你的電腦吧2014-08-08
JavaScript高級程序設(shè)計(第3版)學(xué)習(xí)筆記13 ECMAScript5新特性
通常而言,JavaScript由ECMAScript核心、BOM和DOM三部分構(gòu)成,前面的文章將ECMAScript核心部分粗略的過了一篇2012-10-10
深入探討JavaScript的最基本部分之執(zhí)行上下文
今天小編就為大家分享一篇關(guān)于深入探討JavaScript的最基本部分之執(zhí)行上下文,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-02-02

