ASP.NET Core + Webpack (HMR) не видит файл - PullRequest
0 голосов
/ 09 ноября 2018

Я настраиваю веб-пакет HMR для проекта ASP.NET.

Вот мой webpack.config.js код файла со всеми путями:

  const path = require('path');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const CopyWebpackPlugin = require('copy-webpack-plugin');
const devMode = process.env.NODE_ENV !== 'production';
let dist = 'wwwroot'

module.exports = {
  mode: 'development',
  entry: {
    app: './src/js/app.js'
  },
  output: {
    path: path.resolve(__dirname, dist),
    filename: 'js/[name].min.js',
    publicPath: dist +'/'
  },
  resolve: {
    extensions: ['.ts', '.js']
  },
  module: {
    rules: [
        {
          test: /\.js$/,
          exclude: /node_modules/,
          use: {
            loader: 'babel-loader',
            options: {
              cacheDirectory: true
            }
          }
        },
        {
          test: /\.ts$/,
          use: [
              {
                loader: 'awesome-typescript-loader',
                options: { configFileName: path.resolve(__dirname, 'tsconfig.json') }
              },
          ]
        },
        {
          test: /\.s?[ac]ss$/,
          use: ['style-loader', MiniCssExtractPlugin.loader, 'css-loader',
              {
                loader: "sass-loader",
                options: {
                  includePaths: ["./src/sass"]
                }
              }
          ]
        },
        {
          test: /\.(png|jp(e*)g|gif|svg)$/,
          use: [
              {
                loader: 'file-loader',
                options: {
                  name: "[name].[ext]",
                  outputPath: 'img/',
                  publicPath: '../images/',
                }
              }
          ]
        },
        {
          test: /\.(woff|woff2|eot|ttf|otf)$/,
          use: [
              {
                loader: 'file-loader',
                options: {
                  name: "[name].[ext]",
                  outputPath: 'fonts/',
                  publicPath: '../fonts/',
                }
              }

          ]
        },
        {
          test: /\.svg$/,
          loader: 'svg-inline-loader',
          options: {
            name: "[name].[ext]",
            outputPath: 'img/',
            publicPath: '../images/',
          }
        }
    ]
  },
  resolve: {
    alias: {
      "jquery.validation": "jquery-validation/dist/jquery.validate.js"
    }
  },
  plugins: [
      new CleanWebpackPlugin(dist, {}),
      new MiniCssExtractPlugin({
        filename: "css/[name].min.css",
        chunkFilename: "[id].css",
      }),
      new CopyWebpackPlugin([
          {
            from: './src/img',
            to: 'images',
            toType: 'dir'
          }
      ]),
  ],
}

Я добавил HMR через npm install aspnet-webpack webpack-hot-middleware webpack-dev-middleware -D

И добавил код в Startup.cs:

 app.UseWebpackDevMiddleware(new WebpackDevMiddlewareOptions
            {
                HotModuleReplacement = true
            });

А вот как я пытаюсь использовать скрипт в _Layout.cshtml файле

<script src="~/js/app.min.js" asp-append-version="true"></script>

Но я получаю эту ошибку, и я не понимаю, почему; У меня есть папка wwwroot и файл в ней.

enter image description here

Я пытался пересобрать и очистить проект, но это не помогает.

Как мне решить эту проблему?

1 Ответ

0 голосов
/ 09 ноября 2018

Так что я просто обновляю конфигурацию webpack следующим образом

  const path = require('path');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const CopyWebpackPlugin = require('copy-webpack-plugin');
let dist = 'src'
module.exports = {
   mode: 'development',
   entry: {
    app: './wwwroot/source/app.js'
    },
   output: {
      path: path.resolve(__dirname, dist),
      filename: '[name].min.js',
      publicPath: 'src/'
   },
   module: {
    rules: [
        {
          test: /\.js$/,
          exclude: /node_modules/,
          use: {
            loader: 'babel-loader',
            options: {
              cacheDirectory: true
            }
          }
        },
        {
          test: /\.ts$/,
          use: [
              {
                loader: 'awesome-typescript-loader',
                options: { configFileName: path.resolve(__dirname, 'tsconfig.json') }
              },
          ]
        },
        {
          test: /\.s?[ac]ss$/,
          use: ['style-loader', MiniCssExtractPlugin.loader, 'css-loader',
              {
                loader: "sass-loader",
                options: {
                  includePaths: ["./wwwroot/sass"]
                }
              }
          ]
        },
        {
          test: /\.(png|jp(e*)g|gif|svg)$/,
          use: [
              {
                loader: 'file-loader',
                options: {
                  name: "[name].[ext]",
                  outputPath: 'img/',
                  publicPath: '../images/',
                }
              }
          ]
        },
        {
          test: /\.(woff|woff2|eot|ttf|otf)$/,
          use: [
              {
                loader: 'file-loader',
                options: {
                  name: "[name].[ext]",
                  outputPath: 'fonts/',
                  publicPath: '../fonts/',
                }
              }

          ]
        },
        {
          test: /\.svg$/,
          loader: 'svg-inline-loader',
          options: {
            name: "[name].[ext]",
            outputPath: 'img/',
            publicPath: '../images/',
          }
        }
    ]
  },
  resolve: {
    alias: {
      "jquery.validation": "jquery-validation/dist/jquery.validate.js"
    }
  },
  plugins: [
      new CleanWebpackPlugin(dist, {}),
      new MiniCssExtractPlugin({
        filename: "css/[name].min.css",
        chunkFilename: "[id].css",
      }),
      new CopyWebpackPlugin([
          {
            from: './wwwroot/img',
            to: 'images',
            toType: 'dir'
          }
      ]),
  ],
};

И теперь все в порядке.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...