我正在尝试为Node v6.9.2配置Babel。我想使用async
/ await
构造。
因为我是Babel和所有Node基础架构的新手,所以我很困惑如何正确配置它:
我应该使用什么预设? Node已经实现了大部分ES6功能。因此,出于性能原因,我不希望Babel转换Node 6.9.x已经支持的功能(箭头功能,新导入机制等)。
我应该包含哪些插件,以便我可以使用async / await?在那里我也很困惑,因为经过一些研究后我发现了几个插件:syntax-async-functions
,transform-async-to-generator
等等。
.babelrc
的示例会有所帮助。
由于
答案 0 :(得分:15)
我应该使用什么预设?
您无需使用任何预设。预设只是插件的集合,如果您想要转换一组功能(例如所有带有preset-es2015
的ES2015),它会更容易使用。但是,当您只想转换这些功能时,只需包含相应的插件。
我应该包含哪些插件,以便我可以使用async / await?
由于节点6支持生成器,因此您可以将transform-async-to-generator
与.babelrc
一起使用:
{
"plugins": ["transform-async-to-generator"]
}
当然,如果您需要转换更多不受支持的功能,则需要添加插件。
babel-preset-env
babel-preset-env自动确定指定环境所需的插件。这不包括任何不必要的插件。要指定当前的节点版本,您将使用此.babelrc
:
{
"presets": [
["env", {
"targets": {
"node": "current"
}
}]
]
}
答案 1 :(得分:10)
对节点6.x使用Babel预设:
要查看给定节点版本支持的ES功能,请参阅:
特别是async
/ await
支持,请参阅:
如果您使用Node v7.x(当前版本),那么您可以使用--harmony
标志并本地使用async
/ await
而不进行转换。
Node v8.x(可用作夜间版本)甚至不需要--harmony
标记。
但请注意,Node不支持import
/ export
- 知道为什么请参阅: