Webpack не обслуживает css файл - PullRequest
0 голосов
/ 20 февраля 2020

Я довольно новичок в Webpack 4 и изо всех сил пытаюсь понять, почему я не могу обслуживать свои css файлы. По сути, я запускаю свой dev-сервер, используя npm start, затем я могу обслуживать свой javascript, используя http://localhost:9000/js/app.bundle.js, но когда я пытаюсь сделать то же самое для моего css файла, это дает 404 http://localhost:9000/css/app.css

Мой полный config -

const path = require('path');
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const CopyPlugin = require('copy-webpack-plugin');
const { CleanWebpackPlugin } = require('clean-webpack-plugin');

module.exports = {
  mode:  'development',
  entry: {
    app: ['./src/js/main.js','./src/scss/style.scss'],
    admin: ['./src/js/admin.js', './src/scss/admin.scss']

  },
  output: {
    filename: 'js/[name].bundle.js',
    path: path.resolve(__dirname, 'dist'),
  },
  module: {
    rules: [

      {
        test: /\.(sa|sc|c)ss$/,
        use: [
            MiniCssExtractPlugin.loader,
          {
          loader: 'css-loader',
          },
          {
            loader: 'postcss-loader',
            options: {
              plugins: function () {
                return [
                  require('autoprefixer')
                ];
              }
            }
          },
          {
          loader: 'sass-loader',
          }
        ]
      },
      {
        test: /\.(svg|jpg|png|gif)$/,
        use: {
          loader: 'file-loader',
          options: {
            name: 'assets/img/[name].[ext]',
          }
        }
      },
      {
        test: /\.(woff|woff2|eot|ttf|otf)$/,
        use: {
          loader: 'url-loader',
          options: {
            name: 'assets/fonts/[name].[ext]',
          }
        }
      },
    ],
  },

  plugins: [
    new CleanWebpackPlugin(),
    new MiniCssExtractPlugin({
      filename: "/css/[name].css",
    }),
    new CopyPlugin([
      {from: './src/img', to: 'img'},
      {from: './src/icon', to: 'icon'},
      {from: './src/fonts', to: 'fonts'},
    ]),
  ],
  devServer: {
    contentBase: path.resolve(__dirname, 'dist'),
    port: 9000
  },
};

, когда я запускаю npm run build, я вижу файлы в правильных подкаталогах, например:

/dist/css/app.css
/dist/css/admin.css
/dist/js/app.bundle.js
/dist/js/admin.bundle.js

Если я беру CleanWebpackPlugin() out run npm run build, то npm start файл обслуживается, но я не понимаю, почему он не может обслуживать это, когда он работает в памяти.

Это также работает, внесите следующее изменение

new MiniCssExtractPlugin({
      filename: "/css/[name].css",  Remove this
      filename: "[name].css"  Add this
    }),

Однако тогда я не получаю структуру подкаталога, которую я хочу.

1 Ответ

0 голосов
/ 20 февраля 2020

Так что, похоже, все, что у меня было в порядке, мне просто нужно было удалить /

например

new MiniCssExtractPlugin({
      filename: "/css/[name].css",  replace this line
      filename: "css/[name].css"  with this line
    }),
...