我正在尝试设置Babel7。以前从未使用过Babel,所以我真的是从头开始。我已经成功安装和使用@babel/plugin-proposal-optional-chaining
,但是我在babel-plugin-root-import
方面苦苦挣扎。
这是我的package.json
//package.json
"scripts": {
"start": "nodemon src/index.js --exec babel-node"
},
"devDependencies": {
"@babel/cli": "^7.0.0-beta.51",
"@babel/core": "^7.0.0-beta.51",
"@babel/node": "^7.0.0-beta.51",
"@babel/preset-env": "^7.0.0-beta.51"
},
"dependencies": {
"@babel/plugin-proposal-optional-chaining": "^7.0.0-beta.51",
"@babel/polyfill": "^7.0.0-beta.51",
"babel-plugin-root-import": "^6.1.0"
}
//babel.config.js
module.exports = {
"presets": ["@babel/preset-env"],
"plugins": [
["@babel/plugin-proposal-optional-chaining"],
["babel-plugin-root-import",{
"rootPathPrefix": "@"
}]
]
};
下面是我的代码:
//src/index.js
require("./foo/index.js")();
//src/foo/index.js
module.exports = function() {
console.log("Foo loaded")
}
执行上面的代码时,我在控制台中得到Foo loaded
。
当我使用以下命令更改src / index.js时:
//src/index.js
require("@/foo/index.js")();
我收到以下错误:
internal/modules/cjs/loader.js:596
throw err;
^
Error: Cannot find module '../foo/index.js'
at Function.Module._resolveFilename (internal/modules/cjs/loader.js:594:15)
at Function.Module._load (internal/modules/cjs/loader.js:520:25)
at Module.require (internal/modules/cjs/loader.js:650:17)
at require (internal/modules/cjs/helpers.js:20:18)
at Object.<anonymous> (C:\Node.js\dev\babel7\src/index.js:2:1)
at Module._compile (internal/modules/cjs/loader.js:702:30)
at Module._compile (C:\Node.js\dev\babel7\node_modules\pirates\lib\index.js:91:24)
at Module._extensions..js (internal/modules/cjs/loader.js:713:10)
at Object.newLoader [as .js] (C:\Node.js\dev\babel7\node_modules\pirates\lib\index.js:96:7)
at Module.load (internal/modules/cjs/loader.js:612:32)
[nodemon] app crashed - waiting for file changes before starting...
如果我未在babel.config.js中设置rootPathPrefix,那么我也无法将插件使用以〜开头的路径,这应该是默认值。 怎么了?
非常感谢!
答案 0 :(得分:0)
如果直接用npx babel src/index.js
运行babel-cli只是为了检查输出,您会发现root import插件正确更改了:
require("@/foo/index.js")();
进入:
require("../foo/index.js")();
@
(项目根目录)已正确替换为index.js
..
文件
如果您希望@
引用root/src
,则可以设置"rootPathSuffix": "src"
选项。如果没有该选项,则必须这样做:
require("@/src/foo/index.js")();