找不到模块'@babel/core'

新手上路,请多包涵

我正在关注这个 webpack4/react 教程:

https://www.youtube.com/watch?v=deyxI-6C2u4

我一直遵循它,直到他运行 npm start 的部分。不同的是,他的应用程序运行,而我的应用程序出现错误:

找不到模块’@babel/core’

完整的错误:

 ERROR in ./src/index.js
Module build failed (from ./node_modules/babel-loader/lib/index.js):
Error: Cannot find module '@babel/core'
    at Function.Module._resolveFilename (module.js:547:15)
    at Function.Module._load (module.js:474:25)
    at Module.require (module.js:596:17)
    at require (internal/module.js:11:18)
    at Object.<anonymous> (C:\Users\joeyf\Desktop\Code\Github\webpack4-sample\node_modules\babel-loader\lib\index.js:5:15)
    at Module._compile (module.js:652:30)
    at Object.Module._extensions..js (module.js:663:10)
    at Module.load (module.js:565:32)
    at tryModuleLoad (module.js:505:12)
    at Function.Module._load (module.js:497:3)
 @ multi (webpack)-dev-server/client?http://localhost:8080 (webpack)/hot/dev-server.js ./src/index.js main[2]

我试图重新安装 babel-core 但仍然没有找到。这是我的 package.json:

 {
  "name": "webpack4-sample",
  "version": "1.0.0",
  "description": "A sample setup of Webpack4 with React and Babel",
  "main": "index.js",
  "scripts": {
    "start": "webpack-dev-server --mode development --open --hot",
    "build": "webpack --mode production"
  },
  "author": "Joey Fenny",
  "license": "ISC",
  "dependencies": {
    "babel": "^6.23.0",
    "babel-cli": "^6.26.0",
    "react": "^16.4.2",
    "react-dom": "^16.4.2"
  },
  "devDependencies": {
    "babel-core": "^7.0.0-rc.4",
    "babel-loader": "^8.0.0",
    "babel-preset-env": "^1.7.0",
    "babel-preset-react": "^6.24.1",
    "html-webpack-plugin": "^3.2.0",
    "webpack": "^4.17.1",
    "webpack-cli": "^3.1.0",
    "webpack-dev-server": "^3.1.6"
  }
}

我的 webpack.config.js:

 const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
    entry: './src/index.js',
    output: {
        path: path.join(__dirname, '/dist'),
        filename: 'index_bundle.js'
    },
    module: {
        rules: [{
            test: /\.js$/,
            exclude: path.join(__dirname, '/node_modules'),
            use: {
                loader: 'babel-loader'
            }
        }]
    },
    plugins: [
        new HtmlWebpackPlugin({
            template: './src/index.html'
        })
    ]
}

这是一个 git repo 的链接:

https://gitlab.com/jfny/webpack4-sample

有谁知道发生了什么?谢谢。

原文由 J. Doe 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 1k
2 个回答

尝试运行这个。

 npm install @babel/core --save

babel 改变了他们的包,所以你的 babel-core 不会和 @babel/core 一样。

原文由 Wesgur 发布,翻译遵循 CC BY-SA 4.0 许可协议

最近 Babel 升级到版本 7 更改了节点包的命名。

例如,现在你必须安装

npm install --save-dev @babel/core @babel/preset-env

npm install --save-dev @babel/preset-react

让它与 React 一起工作。然后你可以在你的 .babelrc 文件中使用这些:

 {
  "presets": [
    "@babel/preset-env",
    "@babel/preset-react"
  ]
}

或者作为替代方案,当没有 .babelrc 时,在你的 package.json 中:

 ...
"keywords": [],
"author": "",
"license": "ISC",
"babel": {
  "presets": [
    "@babel/preset-env",
    "@babel/preset-react"
  ]
},
"devDependencies": {
...

如果您想深入了解它,可以查看最近的 Webpack + Babel + React setup

原文由 Robin Wieruch 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题