码迷,mamicode.com
首页 > 其他好文 > 详细

(flag)每日三道面试题(4.25)

时间:2020-04-25 23:24:24      阅读:71      评论:0      收藏:0      [点我收藏+]

标签:回调   array   接收   没有   let   value   rev   result   under   

1.数组如何去重

使用reduce方法累加
reduce使用方法小总结

arr.reduce(callback,初始值)
回调中接收四个参数
//previousValue 初始值/返回值
//currentValue 当前处理的值
//index 索引值
//array数组
arr.reduce((previousValue,currentValue,index,array)=>{
//如果没有return 返回值 previousValue则是underfined
    
}

去重过程:

    const responseList = [
        { id: 1, a: 1 },
        { id: 2, a: 2 },
        { id: 3, a: 3 },
        { id: 1, a: 4 },
    ]
const result=responseList.reduce((acc,cur)=>{
//初始值为空数组来存放每个对象id值
//将每个对象映射成对象的id值对比
const ids=acc.map(item=>item.id);
//如果上个返回数组存在当前id值则返回原值,如果不存在将改项id加入
return ids.includes(cur.id)?acc:[...acc,cur];
},[])
console.log(result)
let result = responseList.reduce((acc, cur) => {
        const ids = acc.map(item => item.id);
        return ids.includes(cur.id) ? acc : [...acc, cur];
    }, [])
    console.log(result)  
 const responseList = [
        { id: 1, a: 1 },
        { id: 2, a: 2 },
        { id: 3, a: 3 },
        { id: 1, a: 4 },
        { id: 3, a: 4 },
        { id: 9, a: 4 },
        { id: 10, a: 4 },
    ]
    let result = responseList.reduce((acc, cur) => {
        const ids = acc.map(item => item.id)//1 (item.id)
        return ids.indexOf(cur.id)===-1 ?  [...acc, cur]:acc //2 (ids.indexOf(cur.id)===-1)
    }, [])
    console.log(result)

(flag)每日三道面试题(4.25)

标签:回调   array   接收   没有   let   value   rev   result   under   

原文地址:https://www.cnblogs.com/halfsoul/p/12775913.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!