在 Express.js 应用程序中,我使用 Babel 在启动之前预编译为 commonjs。编译步骤如下所示:
babel ./src --out-dir dist
node ./dist/bin
作为项目的一部分,我有一个名为my-worker.jswhere I use的文件import syntax:
# my-worker.js
import { parentPort, workerData } from 'worker_threads'
import axios from 'axios'
...
这由以下人员使用other-file.js:
#other-file.js
...
const worker = new Worker(__dirname + '/my-worker.js', { workerData: ... })
...
这工作正常。Babel 将所有文件转换为 commonjs,并且加载工作脚本有效。
但
当我使用@babel/node时,这不起作用:
babel-node ./src/bin
我收到警告:
(node:4865) 警告:要加载 ES 模块,请在 package.json 中设置 "type": "module" 或使用 .mjs 扩展名。
随着错误:
不能在模块外使用 import 语句
我不想使用"type": "module",从那时起我必须明确命名文件扩展名,而且我不确定import X, { y } from ...是否支持语法(我喜欢)。
如果我将工作文件更改为my-worker.mjs,并相应地更改new Worker语句,那么它适用于@babel/node,但不适用于我的生产版本,因为文件名已更改回.js.
我怎样才能@babel/node加载和缓存(我想这是它需要做的?)由 Worker 加载的文件?为什么这适用于@babel而不适用于@babel/node?
我的.babelrc文件如下所示:
{
"presets": [
[
"@babel/preset-env",
{
"useBuiltIns": "usage",
"corejs": 3,
"targets": {
"node": "13"
},
"modules": "commonjs"
}
]
]
}