Favicon не добавляется в папку сборки во время сборки веб-пакета - PullRequest
0 голосов
/ 18 апреля 2019

Я пытаюсь вставить изображение в папку dist, но оно не отображается.

Я включил плагин copy-webpack-, который, как я думал, заставил бы его работать. Я получаю предупреждающее сообщение во время сборки, которое гласит: «ПРЕДУПРЕЖДЕНИЕ при невозможности найти» / Users / developer / Desktop / RecruitsPro / client / public «at» / Users / Developer / Desktop / RecruitsPro / client / public '

webpack.config.js

var webpack = require('webpack');
var path = require('path');
var HtmlWebpackPlugin = require('html-webpack-plugin');
var CopyWebpackPlugin = require('copy-webpack-plugin');
const helpers = require('./helpers');

const VENDOR_LIBS = [
  'axios',
  'ordinal',
  'react',
  'react-activity',
  'react-avatar',
  'react-dom',
  'react-easy-chart',
  'react-is',
  'react-modal',
  'react-redux',
  'react-router-dom',
  'react-stripe-checkout',
  'react-window-size',
  'redux',
  'redux-form',
  'redux-thunk'
];

module.exports = {
  entry: {
    bundle: './client/app/index.js',
    vendor: VENDOR_LIBS
  },
  output: {
    path: path.join(__dirname, 'dist'),
    filename: '[name].[chunkhash].js'
  },
  module: {
    rules: [
      {
        use: 'babel-loader',
        test: /\.js$/,
        exclude: /node_modules/
      },
      {
        use: ['style-loader', 'css-loader'],
        test: /\.css$/
      }
    ]
  },
  plugins: [
    new HtmlWebpackPlugin({
      template: './client/public/index.html'
    }),
    new webpack.DefinePlugin({
      'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV)
    }),
    new CopyWebpackPlugin([{
      from: helpers.root('client/public')
    }])
  ]
};

helpers.js

const path = require('path');

// Helper functions
function root(args) {
  args = Array.prototype.slice.call(arguments, 0);
  return path.join.apply(path, [__dirname].concat('../', ...args));
}

exports.root = root;

Я ожидал, что картина появится.

1 Ответ

0 голосов
/ 20 апреля 2019

Для всех, кому интересно, я должен был добавить этот код в мой массив module.rules.

  {
    test: /\.png$/,
    loader: 'file-loader'
  }
...