1. 程式人生 > >Javascript數組的5種叠代方法

Javascript數組的5種叠代方法

some each 返回值 ron 運行 叠代 兼容 undefine 速度

#Javascript數組的5種叠代方法

數組當中定義了5個叠代方法,傳入這些方法中的函數會接受三個參數,數組項的值,該項在數組的位置,和數組對象本身,以下是5個叠代方法的作用。

1、every方法:

對數組中的每一項運行給定函數,如果該函數對每一項都返回true,則返回true。

let arr1 = [1,2,3,4,5,6];
let arr2 = [-1,-2,-3,-4,-5,-6];
let every1 = arr1.every((item,index,arr)=>{
    return item>0
})
let every2 = arr2.every((item,index,arr)=>{
    return item>0
})
console.log(every1,every2);//true,false

2、filter方法

對數組中的每一項運行給定函數,返回該函數返回true的項組成的數字

let arr1 = [-1,-2,-3,4,5,6];
let arr2 = [1,2,3,-4,-5,-6];
let filter1 = arr1.filter(item=>{
    return item>0
})
let filter2 = arr2.filter((item)=>{
    return item<0
})
console.log(filter1,filter2);//[4,5,6],[-4,-5,-6]

3、some方法

對數組中的每一項運行給定函數,如果該函數對任一項返回true,則返回true。

let arr1 = [1,2,3,4,5,6];
let arr2 = [1,2,3,-4,-5,-6];
let some1= arr1.some(item=>{
    return item>0
})
let some2 = arr2.some((item)=>{
    return item>0
})
console.log(some1,some2);//true,true

4、forEach方法

對數組中的每一項運行給定函數,這個方法沒有返回值。
forEach無法遍歷對象
forEach無法在IE中使用,只是在firefox和chrome中實現了該方法

let arr1 = [1,2,3,4,5,6];
let arr2 = [1,2,3,-4,-5,-6];
let forEach1= arr1.forEach(item=>{
    return item++
})
let forEach2 = arr2.forEach((item)=>{
    return item++
})
console.log(forEach1,forEach2);//undefined,undefined

5、map方法

對數組中的每一項運行給定函數,返回每次調用的結果組成的數組。

let arr1 = [1,2,3,4,5,6];
let arr2 = [-1,-2,-3,-4,-5,-6];
let map1 = arr1.map(item=>{
    return ++item
})
let map2 = arr2.map((item)=>{
    return ++item
})
console.log(map1,map2);//[2, 3, 4, 5, 6, 7] (6) [0, -1, -2, -3, -4, -5];

開發過程中用的比較常用到的就是map,forEach方法,他們是比較相似卻也有不小的區別。
主要在於:
1、map方法是有返回值的,而forEach是沒有的。
2、IE瀏覽器不支持forEach方法,所以要兼容IE瀏覽器的盡量不要使用forEach去遍歷。
3、map方法的速度快於forEach。

Javascript數組的5種叠代方法