未找到入口模块错误 - 在 Webpack 配置文件中

Ama*_*yaz 6 reactjs webpack webpack-dev-server webpack-2 webpack-4

我正在尝试为 ReactJs 设置 webpack。我不知道我的 Webpack 配置文件有什么问题,它给了我

未找到条目模块中的错误:错误:无法解析“D:\ wd \ javascript \ Projects \ ReactJS-Basics中的“./src”

代码在这里 - 两个文件“Webpack.config.js”和“Package.json”

Webpack.config.js 代码是:

var webpack = require('webpack');
var path = require('path');

var DIST_DIR = path.resolve(__dirname,'dist');
var SRC_DIR = path.resolve(__dirname,'src');

var config = {
    entry: SRC_DIR+'/app/index.js',
    output:{
        path:DIST_DIR+'/app',
        filename:'bundle.js',
        publicPath:'/app/'
    },
    module:{
        rules: [
            {
                test: /\.js?/,
                include: SRC_DIR,
                use:{
                    loader:'babel-loader',
                    query:{
                        presets:['react','es2015','stage-2']
                    }
                }
            }
        ]
    },
    mode: 'development',
    watch: true

}

module.export = config;
Run Code Online (Sandbox Code Playgroud)

Package.json 文件是

{
  "name": "reactjs-basics",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "start": " npm run build",
    "build": "webpack -d && copy src\\app/index.html dist\\index.html && webpack-dev-server --content-base src\\ --inline --hot",
    "build:prod": "webpack -p && cp src\\app/index.html dist\\index.html"
  },
  "author": "",
  "license": "ISC",
  "dependencies": {
    "react": "^16.8.6",
    "react-dom": "^16.8.6"
  },
  "devDependencies": {
    "2015": "0.0.1",
    "babel-core": "^6.26.3",
    "babel-loader": "^8.0.5",
    "babel-preset-es2015": "^6.24.1",
    "babel-preset-react": "^6.24.1",
    "babel-preset-stage-2": "^6.24.1",
    "webpack": "^4.29.6",
    "webpack-cli": "^3.3.0",
    "webpack-dev-server": "^3.2.1"
  }
}
Run Code Online (Sandbox Code Playgroud)

**

作为参考,带有 Webpack 配置代码的文件夹结构我附上了下面的图片

**

文件夹结构请点击这里,代码与文件夹结构并列

div*_*ine 8

你必须修改一些东西

  • 在你的webpack.config.js你有module.export。这是不正确的。它一定要是module.exports
  • 你正在使用babel-core@6.26.3babel-loader@8.0.5. babel-loader@8.*不兼容babel-core@6.*。你必须使用babel-loader@7. 卸载现有的babel-loader 使用npm uninstall -D babel-loader并安装babel-loader@7使用npm install -D babel-loader@7

我注意到的另一件事是,您已mode: 'development'webpack.config.js. 最好mode to development or production通过运行时参数设置

更新

从您的中删除mode&watchwebpack.config.js

mode: 'development',
watch: true
Run Code Online (Sandbox Code Playgroud)

使用以下详细信息更新您的信息package.json

开发模式 你不需要设置watch&当你运行时会为你modewebpack-dev-servernpm run dev

"scripts": {
    "webpack": "webpack",
    "dev": "mkdir -p dist && cp ./src/index.html dist/index.html && webpack-dev-server",
    "prod": "mkdir -p dist && cp ./src/index.html dist/index.html && npm run webpack -- --mode production"
}
Run Code Online (Sandbox Code Playgroud)

要启动,local server您需要在webpack.config.js. 请注意这些指向的directory name内容。devserver

devServer: {
    contentBase: path.join(__dirname, "dist/"),
    port: 9000
},
Run Code Online (Sandbox Code Playgroud)

生产模式执行npm run prod以在生产模式下构建您的项目

运行时可以看到 localhost 处于工作状态。npm run dev该服务器是由webpack-dev-server库启动的。因为production build你必须配置你自己的服务器

让我知道这是否有帮助