在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
前言在实际项目中,最常见可能是在计算、循环逻辑方面的处理,可以使用数组中reduce方法也可以解决很多的问题,使得你的代码风格更加优雅! reduce语法
参数说明reducer函数需要接收4个参数分别是 callback
initialValue
返回值
一些reduce常用方法数组里所有元素的和 const arr = [1, 2, 3, 4]; const result = arr.reduce((acc, cur) => acc + cur) console.log(result) // 10 计算数组中每个元素出现的次数 const nums = ['1', '1', '1', '2', '3']; const countednums = nums.reduce((acc, cur) => { if (cur in acc) { acc[cur]++; } else { acc[cur] = 1; } return acc; }, {}); console.log(countednums); // {1: 3, 2: 1, 3: 1} 扁平化数组 const arr = [['a', 'b'], ['b', 'c'], ['d', 'e']] const flatten = arr => { return arr.reduce((acc, cur) => { return acc.concat(cur) }, []) } console.log(flatten(arr)); // ["a", "b", "b", "c", "d", "e"] 数组去重 const arr = [22,341,124,54,4,21,4,4,1,4,4]; const result = arr.sort().reduce((acc, cur) => { if(acc.length === 0 || acc[acc.length-1] !== cur) { acc.push(cur); } return acc; }, []); console.log(result); // [1, 124, 21, 22, 341, 4, 54] 求数组中最大值 const arr = [1, 2, 3, 5, 1] let result = arr.reduce((acc, cur) => Math.max(acc, cur)) console.log(result) 按照顺序调用promise 这种方式实际上处理的是promise的value,将上一个promise的value作为下一个promise的value进行处理。 const prom1 = a => { return new Promise((resolve => { resolve(a) })) } const prom2 = a => { return new Promise((resolve => { resolve(a * 2) })) } const prom3 = a => { return new Promise((resolve => { resolve(a * 3) })) } const arr = [prom1, prom2, prom3] const result = arr.reduce((all, current) => { return all.then(current) }, Promise.resolve(10)) result.then(res => { console.log(res); }) 最后本文分享了一些在日常开发中比较常用的一些reduce处理方法,你可以直接拿到你的项目中使用,也可以进行二次封装。 到此这篇关于js利用reduce方法让你的代码更加优雅的文章就介绍到这了,更多相关js reduce方法让代码优雅内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论