var arr = ["first","second","third","fourth",3,5,8];
for(var i = 0; i < arr.length;i++){
console.log(arr[i]);
}
//输出:
first
second
third
fourth
3
5
8
var arr = ["first","second",'third' ,"fourth",3,5,8];
for(var i in arr){
console.log(arr[i] +'/' + i);
}
//输出结果为:
first/0
second/1
third/2
fourth/3
3/4
5/5
8/6
var arr = ["first","second",'third' ,"fourth",3,5,8];
for(var item of arr){
console.log(item);
}
//输出结果:
first
second
third
fourth
3
5
8
虽然for… in 、 for… of 都能够变历数组,但是两者还是有很大区别的,先说结论:
var arr = ["first","second",'third' ,"fourth",3,5,8];
//给数组添加新属性
arr.name = 'zhangsan';
for(var item of arr){
console.log(item);
}
//输出:
first
second
third
fourth
3
5
8
console.log('--------------分隔符----------------');
for(var item in arr){
console.log(arr[item] + '/' + item);
}
//输出:
first/0
second/1
third/2
fourth/3
3/4
5/5
8/6
zhangsan/name
从上述代码可知:for...in 循环除了遍历数组元素外,还会遍历自定义属性,for...of只可以循环可迭代的可迭代属性,不可迭代属性在循环中被忽略了
2.foreach方法:被传递给foreach的函数会在数组的每个元素上执行一次,元素作为参数传递给该函数
var arr = ["first","second","third","fourth",3,5,8];
//element 表示arr的单元项,index 表示arr单元项对应的索引值
arr.forEach(function(element,index){
console.log(element + '/' + index);
})
//输出结果:
first/0
second/1
third/2
fourth/3
3/4
5/5
8/6
var arr1 = ["first","second", ,"fourth",3,5,8];
arr1.forEach(function(element,index){
console.log(element + '/' + index);
})
//输出结果
first/0
second/1
fourth/3
3/4
5/5
8/6
var arr = ["first","second",'third' ,"fourth"];
var arr2 = arr.map(function(item){
return item.toUpperCase();
})
console.log(arr2);
//输出:
[FIRST,SECOND,THIRD, FOURTH]
var arr = ["first","second",'third' ,"fourth",3,5,8];
var arr3 = arr.filter(function(item){
if(typeof item == 'number'){
return item;
}
})
console.log(arr3);
//输出结果:
[3,5,8]
every()与filter()的区别是:后者会返回所有符合过滤条件的元素;前者会判断是不是数组中的所有元素都符合条件,并且返回的是布尔值
var arr = ["first","second",'third' ,"fourth",3,5,8];
var bol = arr.every(function(element){
if(typeof element == 'string'){
return element;
}
})
console.log(bol); //false
every()与some()的区别是:前者要求所有元素都符合条件才返回true,后者要求只要有符合条件的就返回true
var arr = ["first","second",'third' ,"fourth",3,5,8];
var bol = arr.some(function(element){
if(typeof element == 'string'){
return element;
}
})
console.log(bol); //true