🎶 Sym - 一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)平台

📕 思源笔记 - 一款桌面端笔记应用,支持 Windows、Mac 和 Linux

🎸 Solo - B3log 分布式社区的博客端节点,欢迎加入下一代社区网络

♏ Vditor - 一款浏览器端的 Markdown 编辑器

Array - unzipWith (advanced)

2019-06-30

描述

创建一个由一系列元素组成的数组,通过 zip 和提供的函数来分解原始数组中的元素。

提示

  • 使用 Math.max.apply() 获取数组中最长的子数组长度
  • 使用 Array.prototype.map() 为每一个元素创建一个数组
  • 使用 Array.prototype.reduce() 和 Array.prototype.forEach() 来对数组中的元素进行元素的重新分组
  • 使用 Array.prototype.map() 和扩展运算符 ... 让每一组中的元素都使用提供的 fn 函数

代码

const unzipWith = (arr, fn) =>
  arr
    .reduce(
      (acc, val) => (val.forEach((v, i) => acc[i].push(v)), acc),
      Array.from({
        length: Math.max(...arr.map(x => x.length))
      }).map(x => [])
    )
    .map(val => fn(...val));

示例

对数组中的同列元素进行相加:

unzipWith([[1, 10, 100], [2, 20, 200]], (...args) => args.reduce((acc, v) => acc + v, 0)); // [3, 30, 300]

返回总目录

每天 30 秒系列之 JavaScript 代码


欢迎注册黑客派社区,开启你的博客之旅。让学习和分享成为一种习惯!

留下你的脚步