为了账号安全,请及时绑定邮箱和手机立即绑定

关于一个分组统计的函数

关于一个分组统计的函数

ABOUTYOU 2019-01-02 22:21:03
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求大佬着重解释下这个
查看完整描述

1 回答

?
红糖糍粑

TA贡献1815条经验 获得超6个赞

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}


查看完整回答
反对 回复 2019-01-02
  • 1 回答
  • 0 关注
  • 378 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信