Опция Webpack 4 devtool не работает с webpack-dev-server - PullRequest
0 голосов
/ 30 апреля 2018

Прежде чем я решил опубликовать эту проблему, я сделал несколько вещей в качестве проверки фона. Итак, моя проблема:

- я использую webpack v4.6.0 и webpack-dev-server v3.1.3 - они отлично работают вместе, но сейчас я пытаюсь настроить исходные карты для своего приложения, кажется, что опция devtool не работает.

По крайней мере, для меня, я попробовал и протестировал каждый вариант из списка:

  • Webpack 4 - Sourcemaps : эта проблема предполагает, что devtool: 'source-map' должно работать из коробки, но это не так для меня
  • как создать исходную карту веб-пакета в исходных файлах : добавление devtoolModuleFilenameTemplate: info =>'file://' + path.resolve(info.absoluteResourcePath).replace(/\\/g, '/') к моей выходной конфигурации не сильно помогло, вместо client.js он показывает index.js для меня, хотя enter image description here enter image description here
  • https://github.com/webpack/webpack/issues/6400: это не точное описание моей проблемы, попытка описанных здесь методов тоже не помогла мне
  • Я пытался использовать webpack.SourceMapDevToolPlugin, но он также не работает с моими настройками, даже когда я удаляю devtools или устанавливаю их в false
  • Я не использую плагин UglifyJS здесь
  • Я знаю, что webpack-dev-server сейчас находится в обслуживании, поэтому я попробовал webpack-serve, но кажется, что исходные карты с ним тоже не работают
  • Я также попробовал пакет source-map-support, но, к счастью, ситуация такая же, как у здесь : enter image description here

Знаете ли вы, будет ли эта проблема исправлена ​​каким-то пиарщиком, или вы пытались решить ее самостоятельно? Любые советы или помощь приветствуется!

Я хотел бы получить вывод, как описано здесь, в блоге с прямыми ссылками на мои файлы и исходный код файла.

Мой webpack.js

// webpack v4.6.0
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const WebpackMd5Hash = require('webpack-md5-hash');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const stylish = require('eslint/lib/formatters/stylish');
const webpack = require('webpack');

module.exports = {
  entry: { main: './src/index.js' },
  output: {
    devtoolModuleFilenameTemplate: info =>
      'file://' + path.resolve(info.absoluteResourcePath).replace(/\\/g, '/'),
    path: path.resolve(__dirname, 'dist'),
    filename: '[name].[hash].js'
  },
  devtool: 'source-map',
  devServer: {
    contentBase: './dist',
    hot: true
  },
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        loader: 'babel-loader'
      },
      {
        test: /\.js$/,
        exclude: /node_modules/,
        loader: 'eslint-loader',
        options: {
          formatter: stylish
        }
      }
    ]
  },
  plugins: [
    // new webpack.SourceMapDevToolPlugin({
    //   filename: '[file].map',
    //   moduleFilenameTemplate: undefined,
    //   fallbackModuleFilenameTemplate: undefined,
    //   append: null,
    //   module: true,
    //   columns: true,
    //   lineToLine: false,
    //   noSources: false,
    //   namespace: ''
    // }),
    new CleanWebpackPlugin('dist', {}),
    new HtmlWebpackPlugin({
      inject: false,
      hash: true,
      template: './src/index.html',
      filename: 'index.html'
    }),
    new WebpackMd5Hash(),
    new webpack.NamedModulesPlugin(),
    new webpack.HotModuleReplacementPlugin()
  ]
};

my package.json

{
  "name": "post",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "storybook": "start-storybook -p 9001 -c .storybook",
    "dev": "webpack-dev-server --mode development --open",
    "build": "webpack --mode production"
  },
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "@storybook/addon-actions": "^3.4.3",
    "@storybook/react": "v4.0.0-alpha.4",
    "babel-cli": "^6.26.0",
    "babel-core": "^6.26.0",
    "babel-loader": "^7.1.4",
    "babel-preset-env": "^1.6.1",
    "babel-preset-react": "^6.24.1",
    "babel-runtime": "^6.26.0",
    "clean-webpack-plugin": "^0.1.19",
    "eslint": "^4.19.1",
    "eslint-config-prettier": "^2.9.0",
    "eslint-loader": "^2.0.0",
    "eslint-plugin-prettier": "^2.6.0",
    "eslint-plugin-react": "^7.7.0",
    "html-webpack-plugin": "^3.2.0",
    "prettier": "^1.12.1",
    "react": "^16.3.2",
    "react-dom": "^16.3.2",
    "webpack": "v4.6.0",
    "webpack-cli": "^2.0.13",
    "webpack-dev-server": "v3.1.3",
    "webpack-md5-hash": "0.0.6",
    "webpack-serve": "^0.3.1"
  },
  "dependencies": {
    "source-map-support": "^0.5.5"
  }
}

мой вывод в консоли: enter image description here

Edit:

Я видел подобный вопрос здесь , но, похоже, никто не отвечает. Ошибка была сделана специально! Это относится не только к ошибкам обработки, но и к каждой ошибке моего приложения. Вот ссылка на мой репозиторий GITHUB: https://github.com/marharyta/webpack-fast-development

ОБНОВЛЕНИЕ 01.05.2018

Я создал еще один репозиторий с настройкой очистителя: https://github.com/marharyta/webpack-4.6.0-test И подробное объяснение того, как я сюда попал: https://medium.com/p/79fb676417f4/edit Авторы веб-пакетов внесли некоторые предложения, но они все равно не сработали: https://github.com/marharyta/webpack-4.6.0-test/issues/1

ОБНОВЛЕНИЕ 02.05.2018

После долгого расследования я разместил свой ответ ниже. Проблема была в ESLint и, возможно, в некоторых режимах маркировки, так как мне приходилось делать это способом CLI. У меня также проблема в загрузчике ESLint здесь: https://github.com/webpack-contrib/eslint-loader/issues/227 Я также создал пост с более подробным описанием здесь: https://medium.com/@riittagirl/how-to-solve-webpack-problems-the-practical-case-79fb676417f4

Ответы [ 2 ]

0 голосов
/ 01 мая 2018

Итак, после долгих попыток и ошибок я наконец-то получил помощь от одного из разработчиков веб-пакетов. Главным вопросом был Эслинт. Если вы загружаете его как загрузчик, это создает неожиданное поведение. Удалив eslint из загрузчиков webpack для js, вы можете это исправить.

Настройка веб-пакета до:

// webpack v4
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const WebpackMd5Hash = require('webpack-md5-hash');
const CleanWebpackPlugin = require('clean-webpack-plugin');

const baseConfig = {
  entry: { main: './src/index.js' },
  output: {
    path: path.resolve(__dirname, 'dist'),
    filename: '[name].[hash].js'
  },
  devServer: {
    contentBase: './dist',
    hot: true,
    open: true
  },
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        **use: [
          { loader: 'babel-loader' },
          {
            loader: 'eslint-loader',
            options: { formatter: require('eslint/lib/formatters/stylish') }
          }**
        ]
      }
    ]
  },
  plugins: [
    new CleanWebpackPlugin('dist'),
    new HtmlWebpackPlugin({
      inject: false,
      hash: true,
      template: './src/index.html',
      filename: 'index.html'
    }),
    new WebpackMd5Hash()
  ]
};

if (process.env.NODE_ENV === 'development') {
  baseConfig.devtool = 'inline-source-map';
}

module.exports = baseConfig

веб-пакет, который работает после:

// webpack v4
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const WebpackMd5Hash = require('webpack-md5-hash');
const CleanWebpackPlugin = require('clean-webpack-plugin');
module.exports = {
  entry: { main: './src/index.js' },
  output: {
    path: path.resolve(__dirname, 'dist'),
    filename: '[name].[hash].js'
  },
  devtool: 'cheap-module-source-map',
  devServer: {
    contentBase: './dist',
    hot: true,
    open: true
  },
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        **use: [{ loader: 'babel-loader' }]**
      }
    ]
  },
  plugins: [
    new CleanWebpackPlugin('dist'),
    new HtmlWebpackPlugin({
      inject: false,
      hash: true,
      template: './src/index.html',
      filename: 'index.html'
    }),
    new WebpackMd5Hash()
  ]
};

my packeje.json выглядит так:

{
  "name": "post",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "build": "webpack --mode=production",
    "start": "NODE_ENV=development webpack-dev-server --mode=development --hot"
  },
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "babel-cli": "^6.26.0",
    "babel-core": "^6.26.0",
    "babel-loader": "^7.1.4",
    "babel-preset-env": "^1.6.1",
    "babel-preset-react": "^6.24.1",
    "babel-runtime": "^6.26.0",
    "clean-webpack-plugin": "^0.1.19",
    "eslint": "^4.19.1",
    "eslint-config-prettier": "^2.9.0",
    "eslint-loader": "^2.0.0",
    "eslint-plugin-prettier": "^2.6.0",
    "eslint-plugin-react": "^7.7.0",
    "html-webpack-plugin": "^3.2.0",
    "prettier": "^1.12.1",
    "react": "^16.3.2",
    "react-dom": "^16.3.2",
    "webpack": "^4.6.0",
    "webpack-cli": "^2.0.13",
    "webpack-md5-hash": "0.0.6"
  },
  "dependencies": {
    "webpack-dev-server": "^3.1.3"
  }
}

Смотрите также предложения по проблеме, которая была создана в моей ветке: https://github.com/marharyta/webpack-4.6.0-test

0 голосов
/ 30 апреля 2018

В webpack4 вам необходимо установить режим в конфигурации вашего webpack. Пожалуйста, добавьте

mode: "development"

В конфигурацию вашего веб-пакета.

Вы можете удалить NamedModulesPlugin, поскольку он уже используется в режиме разработки.

Опция source-map предназначена для производственных сборок. Для вашей сборки dev я бы удалил devtool prop, потому что тогда webpack использует eval по умолчанию. Если это не сработает, попробуйте:

devtool: 'cheap-module-eval-source-map'

Это то, что я использую. Самый минимальный конфиг.

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const stylish = require('eslint/lib/formatters/stylish');
const webpack = require('webpack');

module.exports = {
  mode: 'development',
  entry: { main: './src/index.js' },
  output: {
    filename: '[name].[hash].js'
  },
  resolve: {
    extensions: ['.js', '.jsx']
  },
  devtool: 'cheap-module-eval-source-map',
  devServer: {
    hot: true,
    open: true
  },
  module: {
    rules: [
      {
        test: /\.jsx?$/,
        exclude: /node_modules/,
        use: [
          { loader: 'babel-loader' },
          { loader: 'eslint-loader', options: { formatter: stylish } }
        ]
      }
    ]
  },
  plugins: [
    new CleanWebpackPlugin('dist'),
    new HtmlWebpackPlugin({
      template: './src/index.html'
    }),
    new webpack.HotModuleReplacementPlugin()
  ]
};
...