将Node.js服务器与Webpack捆绑在一起时找不到index.html

时间:2019-01-31 05:02:42

标签: node.js express webpack

我正在尝试设置webpack来捆绑我的后端代码。

我的webpack配置如下:

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const nodeExternals = require('webpack-node-externals');

const outputDirectory = 'dist';

const client = {
  mode: 'production',
  entry: {
    'app': [
      'babel-polyfill',
      './client/index.js'
    ]
  },
  output: {
    path: path.join(__dirname, outputDirectory),
    publicPath: '/',
    filename: 'bundle.js'
  },
  module: {
    rules: [
      { 
        test: /\.(js|jsx)$/, exclude: /node_modules/, loader: 'babel-loader'
      },
      {
        test: /\.css$/,
        use: ['style-loader', 'css-loader']
      },
      {
        test: /\.(gif|svg|jpg|png)$/,
        loader: "file-loader"
      }
    ]
  },
  plugins: [
    new CleanWebpackPlugin([outputDirectory]),
    new HtmlWebpackPlugin({
      template: './index.html',
    })
  ]
}

const server = {
  mode: 'production',
  target: 'node',
  entry: {
    'app': [
      './server/server.js'
    ]
  },
  externals: [nodeExternals()],
  output: {
    path: path.join(__dirname, '/server'),
    filename: 'server.bundle.js'
  }
}

module.exports = [client, server]

如果我运行非webpack server.js,一切正常。但是,如果我运行webpack捆绑的server.bundle.js,则会抛出异常:

Error: ENOENT: no such file or directory, stat '/dist/index.html'

两个服务器文件都在同一目录中。以前有人遇到过这个问题吗?

1 个答案:

答案 0 :(得分:1)

我知道了,webpack的文档中没有明确说明,但是在使用express时需要配置“ node”属性

例如将此添加到您的配置

  node: {
    // Need this when working with express, otherwise the build fails
    __dirname: false,   // if you don't put this is, __dirname
    __filename: false,  // and __filename return blank or /
  },