数组-常⽤的数组遍历⽅法
常⽤的11种数组遍历⽅法:
1、for循环语句
2、forEach数组对象内置⽅法 (es5) 
3、map数组对象内置⽅法 
4、filter数组对象内置⽅法 
5、reduce数组对象内置⽅法 
6、some数组对象内置⽅法 和 every数组对象内置⽅法
7、indexOf数组对象内置⽅法 和 lastIndexOf数组对象内置⽅法 
8、for in循环语句 和 for of循环语句(es6)
1.for循环
简洁明了,通俗易懂,性能最好
eg1:
let arr = [1, 2, 3, 4, 5];
for(let i = 0; i < arr.length; i++) {
  arr[i] = arr[i] * 2
}
console.log(arr); //[2, 4, 6, 8, 10]
eg2:使⽤变量,将长度保存起来,当数组长度很⼤时,优化效果明显
let arr = [11,22,33,44,55];
for(let i = 0;let len = arr.length,i<len;i++){
arr[i] = arr[i] *2;
}
console.log(arr)
2. forEach
forEach对于空数组是不会执⾏回调函数的filter过滤对象数组
可接收三个参数(当前元素(必填),当前元素的索引,当前元素所属的数组对象)return 不能中断函数执⾏,所以没有返回值,也不可以使⽤break语句中断循环
不能改变原数组,性能没有for⾼ 有兼容性
3.map
可以return返回值
⼀般(通过函数⽅法操作)⽤来映射为⼀个新数组
不改变原数组
let arr = [1, 2, 3, 4, 5];
let arrs = arr.map((value, index, array) => {
return value * 2;
});
console.log(arrs); //[2, 4, 6, 8, 10]
4、 filter
⼀般通过函数⽅法,过滤出符合要求的项,返回出来⼀个新数组
let arr = [1, 2, 3, 4, 5];
let temp=arr.filter((value)=>{
return value>2
});
console.log(temp);  //[3, 4, 5]
5、 reduce
可以实现⼀个累加器的功能,将数组的每个值(从左到右)累加起来
6、 some和every
执⾏箭头函数⾥的⽅法,返回⼀个布尔真假
some只要有,有返回真
换成every,只要不是全都符合,就返回假
let arr = [1, 2, 3, 4, 5];
let temp=arr.some((item)=>{
return item>3;
});
console.log(temp);
7、 indexOf和lastIndexOf
和字符串中该⽅法⼏乎⼀样
只要到⼀个满⾜条件的值就不继续执⾏了
返回满⾜条件值的下标,否则返回-1
let arr = [1, 2, 3, 4, 5];
let temp=arr.indexOf(4);
console.log(temp);  //3
indexOf从左往右遍历,lastIndexOf从右往左遍历
8、 for in和for of
for of,只能遍历数组的值,不能遍历对象
for in,可以遍历数组的下标,数组的值,或者对象的键值对
for…in遍历数组的index值(下标)的数据类型是字符串,正常的index值是数字
let arr = [1, 2, 3, 4, 5];
for (let i of arr) {
console.log(i); // 1, 2, 3, 4, 5
}
下⾯是for  in的例⼦,既可以遍历数组,也可以遍历对象
let arr = ["a", "b", "c", "d", "e"];
for (let i in arr) {
console.log(i);      // 0,1,2,3,4
console.log(arr[i]);  //a,b,c,d,e
}
for  in循环对象
let obj = {"name":"zyw","age":32,"job":"web"};
for (let i in obj) {
console.log(i);      // name,age,job
console.log(obj[i]);  //zyw,32,web
}
总结
⼀般的循环⽤for,for…in,for…of和forEach
需要映射为新数组的⽤map,
需要筛选出想要的⽤filter,
数值需要进⾏累加的⽤reduce,
如果要⼀些值⽤some和every,
如果想知道值的具体位置的可以⽤indexOf和lastIndexOf