ES6遍历数组map()⽅法、filter()、forEach()⽅法的区别
map()根据当前数组映射出⼀个新的数组,map和forEach等遍历⽅法不同,在forEach中return语句是没有任何效果的,⽽map则可以改变当前循环的值,返回⼀个新的被改变过值之后的数组(map需return),⼀般⽤来处理需要修改某⼀个数组的值。
let arr1 = [1,2,3];
let arr2 = arr1.map((value,key,arr) => {
console.log(value) // 1,2,3
console.log(key) // 0,1,2
console.log(arr) //[1,2,3] [1,2,3] [1,2,3] 有若⼲个值就会遍历若⼲个⾃⾝的数组
return value * value;
})
console.log(arr1); // [ 1, 2, 3 ]
console.log(arr2); // [ 1, 4, 9 ]
也可以遍历对象
let products= [
{ name: "马云", price: 200 },
{ name: "马化腾", price: 140 },
{ name: "马冬梅", price: 20 },
{ name: "马某", price: 10 }
]
var newProducts= products.map(product => {
return {
// 改变循环的值得到⼀个新的数组
name: "**" + product.name + "**",
price: product.price / 2
};
});
console.log(newProducts)
/*
0: {name: "**马云**", price: 100}
1: {name: "**马化腾**", price: 70}
2: {name: "**马冬梅**", price: 10}
3: {name: "**马某**", price: 5}
*/
filter()⽅法,⽤来过滤数组,返回⼀个新的数组,filter⽅法需要在循环的时候判断⼀下是true还是false,是true才会返回这个元素;
let arr1 = [1,2,3];
let arr2 = arr1.filter((value,key,arr) => {
console.log(value) // 1,2,3
console.log(key) // 0,1,2
console.log(arr) // [1,2,3]
return value >= 3 ? false : true;
})
console.log(arr1); // [ 1, 2, 3 ]
console.log(arr2); // [ 1, 2 ]
filter可以⽤来去除不符合的数组
let arr = [1,2,3]
let newArr = arr.filter(item => item>=3)
console.log(newArr)// [3]
filter() 去掉空字符串、undefined、null
let arr = ['','1','2',undefined,'3.jpg',undefined]
let newArr = arr.filter(item => item)
console.log(newArr) // arr=['1','2','3.jpg']
filter数组去重的操作
let arr = [1, 2, 2, 3, 4, 5, 5,5, 6,6,6,6];
let newArr = arr.filter((x, index,self)=>self.indexOf(x)===index)
console.log(newArr)
/
/newArr=[1,2,3,4,5,6]
filter筛选数组对象
let arr = [
{a:'苹果',b:'⾯包',c:'吃'},
{a:'⾹蕉',b:'⾯包',c:'不吃'},
{a:'⾹蕉',b:'苹果',c:'吃'},
{a:'苹果',b:'⾹蕉',c:'不吃'},
]
console.log(arr.filter(item => item.a=== '苹果' ))
//[{a:'苹果',b:'⾯包',c:'吃'},{a:'苹果',b:'⾹蕉',c:'不吃'}]
如果是多个条件的筛选的话 可以在item后加上这样类型的判断
item => (a?item.a === a : true) && (b?item.b === b : true) && (c?item.c === c : true)
a和b和c 的值都是需要我们提前预设的
forEach遍历⽅式遍历数组全部元素,利⽤回调函数对数组进⾏操作,⾃动遍历数组.length次,且⽆法break中途跳出循环,不可控、不⽀持return操作输出,return只⽤于控制循环是否跳出当前循环
filter过滤对象数组[1,2,3,4].forEach(n=>{
console.log(n)
// 1 2 3 4
})
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论