京东面试题,当时只想起来几个简单的方法,回头一总结,还真不少。下面以从1到100的数组为例,列举想到的所有数组遍历方法。若有没写出来的,欢迎大家评论补充。
const arr = Array.from(Array(100), (itm,idx) => idx+1);
1、for循环(实现数组求和)
let sum = 0;
for(let i=0; i<arr.length; i++){
sum += arr[i]
}
2、forEach(实现数组求和)
let sum = 0;
arr.forEach(item=>{
sum += item
})
3、map(返回一个新数组,数组中的每一项为元素本身与其索引的和)
arr.map((item,index) => {
return item + index
})
4、filter(实现筛选前50项中的偶数,返回一个新数组)
arr.filter((item,index) => {
return index<50 && item%2==0
})
5、some(判断前50项中是否包含数字n,返回一个布尔值)
const n = 99;
arr.some((item,index) => {
return item==99 && index<50
})
6、every(判断所有元素与其索引的和是否都是正数,返回一个布尔值)
arr.every((item,index) => {
return item+index > 0
})
7、reduce(实现数组求和)
const sum = arr.reduce((val,item,index) => {
//val初始值为第一个元素值,在每一次循环中,更新为上一次循环时回调函数的返回值,并在reduce循环结束后将该值返回
return val + item
})
8、for...of(实现数组求和)
let sum = 0;
for(const item of arr){
sum += item
}
9、for...in(只能拿到索引,勉强也算是遍历了数组吧)
for(const index in arr){
console.log(index)
}
10、find(找出第一个大于n的元素,不一定所有的元素都被遍历到)
const n = 50
arr.find(item => {
return item > n
})
11、findIndex(找出第一个大于n元素的索引,不一定所有元素都被遍历到)
const n = 150
arr.findIndex(item => {
return item > n
})
更多面试题可参考大厂高级前端面试题