关于一个分组统计的函数

const countBy = (arr, fn) =>
  arr.map(typeof fn === 'function' ? fn : val => val[fn]).reduce((acc, val, i) => {
    acc[val] = (acc[val] || 0) + 1;    return acc;
  }, {});
countBy([6.1, 4.2, 6.3], Math.floor); // {4: 1, 6: 2}countBy(['one', 'two', 'three'], 'length'); // {3: 2, 5: 1}

我的疑问是map里面是怎么运行,arr.map() 主要是这个三元表达式结果是应该是进入fn,而不是后面的reduce求大佬着重解释下这个


ABOUTYOU
浏览 379回答 1
1回答

红糖糍粑

const countBy = (arr, fn) =>{  // 判断 fn 是否为函数,如果是函数 tempFn = fn ,如果不是函数 tempFn = val => val[fn]   const tempFn = typeof fn === 'function' ? fn : val => val[fn]  // const tempFn = typeof fn === 'function' ? fn : (val => val[fn])   const tempArr = arr.map(tempFn)  // 遍历 tempArr 统计相同的元素个数   return tempArr.reduce((acc, val, i) => {     acc[val] = (acc[val] || 0) + 1;    return acc;   }, {}); } countBy([6.1, 4.2, 6.3], Math.floor);// tempFn = Math.floor// tempArr = arr.map(tempFn) // tempArr = [6, 4, 6]// 使用 reduce 统计相同元素个数 {6:2,4:1}countBy(['one', 'two', 'three'], 'length');// tempFn = val => val['length']// tempArr = arr.map(tempFn) // tempArr = [3, 3, 5]// 使用 reduce 统计相同元素个数 {3:2,5:1}
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript