JavaScript中遍歷的十種方法總結(jié)
1.while循環(huán)
while后面跟循環(huán)條件和執(zhí)行語句,只要滿足條件,就會一直執(zhí)行里面的執(zhí)行
var i = 0
while(i<10){
console.log(i)
i++
}
2.do...while循環(huán)
與while相似,但是他會先執(zhí)行一次,再做判斷條件
var i=0
do{
console,log(i)
i++
}while(i<10)
3.for循環(huán)
var arr = [0,1,2,3]
for(let i = 0;i < arr.length;i++){
console.log(i)
}
4.forEach循環(huán)
var arr = [0,1,2,3]
arr.forEach((item,index)=>{
console.log(`下標(biāo)${index}的數(shù)為${item}`)
})
5.for...in循環(huán)
一般用來遍歷對象的屬性,遍歷數(shù)組的話拿到的是下標(biāo)
var obj = {name:'snail',age:18}
for(var key in obj){
console.log(key)
}
6.for...of循環(huán)
可以遍歷拿到每一個元素
var str = 'snail'
for(var item of str){
console.log(item)
}
7.map映射
map方法將數(shù)組的所有成員依次傳入?yún)?shù)函數(shù),然后把每一次的執(zhí)行結(jié)果組成一個新數(shù)組返回。
該函數(shù)調(diào)用時,map方法向它傳入三個參數(shù):當(dāng)前成員、當(dāng)前位置和數(shù)組本身。
注意:是返回一個新數(shù)組,而不會改變原數(shù)組。
var arr = [0,1,2,3]
arr.map((item)=>{
return item*2
})
8.filter()過濾循環(huán)
filter方法用于過濾數(shù)組成員,滿足條件的成員組成一個新數(shù)組返回。
它的參數(shù)是一個函數(shù),所有數(shù)組成員依次執(zhí)行該函數(shù),返回結(jié)果為true的成員組成一個新數(shù)組返回。該方法不會改變原數(shù)組。
var arr = [0,4,2,3,5]
arr.filter((item)=>{
return (item>3)
})
9.some(),every()遍歷
統(tǒng)計數(shù)組是否滿足某個條件,這兩個方法返回一個布爾值,表示判斷數(shù)組成員是否符合某種條件。
它們接受一個函數(shù)作為參數(shù),所有數(shù)組成員依次執(zhí)行該函數(shù)。該函數(shù)接受三個參數(shù):當(dāng)前成員、當(dāng)前位置和整個數(shù)組,然后返回一個布爾值。
some方法是只要一個成員的返回值是true,則整個some方法的返回值就是true,否則返回false。
every方法則相反,所有成員的返回值都是true,整個every方法才返回true,否則返回false。兩相比較,some()只要有一個是true,便返回true;而every()只要有一個是false,便返回false.
這兩個方法在實際開發(fā)中,大有可用之處。比如在判定用戶是否勾選了不可操作的數(shù)據(jù),或者是否勾選了一條可以操作的數(shù)據(jù)可以使用這兩個方法遍歷循環(huán)數(shù)組。
10.reduce()遍歷
reduce方法第一個參數(shù)是一個函數(shù)。該函數(shù)接受以下四個參數(shù)。
1.Accumulator(累計器)
2.Current Value(當(dāng)前值)
3.Current Index(當(dāng)前索引)
4.Source Array(源數(shù)組)
函數(shù)的返回值分配給累計器,該返回值在數(shù)組的每個迭代中被記住,并最后成為最終的單個結(jié)果值。
這四個參數(shù)之中,只有前兩個是必須的,后兩個則是可選的。
到此這篇關(guān)于JavaScript中遍歷的十種方法的文章就介紹到這了,更多相關(guān)JavaScript遍歷方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
完美解決input[type=number]無法顯示非數(shù)字字符的問題
下面小編就為大家?guī)硪黄昝澜鉀Qinput[type=number]無法顯示非數(shù)字字符的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02

