Не удается найти index.html при объединении сервера Node.js с Webpack - PullRequest
0 голосов
/ 31 января 2019

Я пытаюсь настроить веб-пакет для связывания моего внутреннего кода.

Моя конфигурация веб-пакета выглядит следующим образом:

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]

Если я запускаю non-webpack server.js, все работает нормально.Тем не менее, если я запускаю упакованный в веб-пакете server.bundle.js, экспресс-броски:

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

Оба файла сервера находятся в одном каталоге.Кто-нибудь сталкивался с этой проблемой раньше?

1 Ответ

0 голосов
/ 31 января 2019

Я понял, это явно не указано в документации веб-пакета, но вам нужно настроить свойство "node" при использовании express

Ex.добавьте это в ваш конфиг

  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 /
  },
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...