Javascript - 数组上的 flatMap 方法 - (flatMap 不是函数)

Posted

技术标签:

【中文标题】Javascript - 数组上的 flatMap 方法 - (flatMap 不是函数)【英文标题】:Javascript - flatMap method over array - (flatMap is not a function) 【发布时间】:2019-08-27 01:55:27 【问题描述】:

根据 Mozilla 开发者网站:

The flatMap() method first maps each element using a mapping function, then flattens the result into a new array. It is identical to a map followed by a flat of depth 1, but flatMap is often quite useful, as merging both into one method is slightly more efficient.

例子:

let arr = [1, 2, 4, 2, 3, 3, 4, 5, 5, 5, 8, 8, 9, 10];

const flatMap = arr.flatMap(x => x);
console.log(flatMap);

TypeError: arr.flatMap() is not a function

为什么会返回这个错误?

编辑

我正在通过 Atom 文本编辑器运行它,并使用 HomeBrew 使用 brew upgrade node 将其更新到最新版本,但它仍然给我同样的错误。

我也试过npm install n -g

【问题讨论】:

您的浏览器可能还不支持它。但是,在该数组上使用 flatMap 有什么意义? 我只是想看看它是否有效,然后也测试其他值。 The documentation 有很多例子,如果你的浏览器不支持alternatives developer.mozilla.org/en-US/docs/Web/javascript/Reference/… 这只是browser compatibility的问题,因为它只支持新的浏览器。 【参考方案1】:

我在用 jest 测试时得到了这个,这是因为 flatmap 只是 part of node 11 而我使用的是节点 10。

作为一种解决方法,我在setupTests.ts 中添加了require('core-js/stable');

我想也有一些浏览器不会有这个。因此,我还将在我的应用程序导入中的某处放置该 require 行。

【讨论】:

【参考方案2】:

表示你使用的浏览器或其他开发环境不支持Array.prototype.flatMap(目前Edge和IE都不支持)。可以使用表here。

另请注意,它主要用于多维数组(避免链接mapflat,因此flatMap)。

【讨论】:

在我的情况下,我只会使用自制软件进行升级,对吗? brew upgrade node 对吗? 更简单(不需要 Homebrew)-npm install n -g(参见this answer)。 只需卸载 node 并使用 nvm 重新安装它:github.com/creationix/nvm【参考方案3】:

您的浏览器似乎不支持flatMap。 以下是支持的浏览器的完整列表:https://caniuse.com/#search=flatMap

如果你真的想使用它,这里是一个 polyfill,它将支持 ES3:https://www.npmjs.com/package/array.prototype.flatmap

顺便说一句,它在应用于多维数组时很有用!

【讨论】:

欣赏它,我在 atom 上运行它并相信我将它更新为最新版本的节点,但仍然无法正常工作。 我建议在节点上开发时使用:github.com/creationix/nvm :)

以上是关于Javascript - 数组上的 flatMap 方法 - (flatMap 不是函数)的主要内容,如果未能解决你的问题,请参考以下文章

javascript 中等flatMap示例

Swift - 使用 map/reduce/flatmap 将数组字典减少为相同类型的单个数组

RxSwift:嵌套可观察对象上的 FlatMap

理解Swift中map 和 flatMap对集合的作用

如何在二维数组的范围内使用 flatMap() 和 reduce()

Kotlin flatMap 高级函数 操作数组的数组