Задать вопрос
@kiberlain

Почему не отображаются изображения?

Дали готовый конфиг с pug-ом на борту, всё отлично собирается-обновляется-билдится за исключением того что img(src="images/картинка") ни коннектит картинку, пробовал разные урлы включая http://localhost:8080/images/картинка - бесполезно. Где ошибка?

const autoprefixer = require('autoprefixer'),
      webpack      = require('webpack'),
      notify       = require('webpack-build-notifier'),
      clean        = require('clean-webpack-plugin'),
      path         = require('path'),
      css          = require('mini-css-extract-plugin'),
      mode         = checkMode(process.argv[process.argv.length - 1], 'production');

module.exports = {
  mode:mode,

  entry:{
    index:path.resolve(__dirname,'src/index.js'),
  },

  output:{
    path:path.resolve(__dirname, 'build'),
    filename:'js/[name].js',
  },

  module:{
    rules:[
      // JS
      {
        test:/\.js?$/,
        exclude:/node_modules/,
        loader:'babel-loader',
        query:{
          presets:['es2015']
        }
      },

      // PUG
      {
        test:/\.pug$/,
        use:[

          {
            loader:'file-loader',
            options:{
              name:'[name].html',
            }
          },

          {
            loader:'pug-html-loader',
            options:{
              pretty:true
            }
          },

        ],
      },

      // SCSS
      {
        test:/\.(scss)$/,
        use:[

          {
            loader:css.loader,
            options:{
              publicPath:'../',
              sourceMap:true,
            }
          },

          {
            loader:'css-loader',
            options:{
              sourceMap:true,
              minimize: mode,
            }
          },

          {
            loader:'resolve-url-loader',
            options:{
            }
          },

          {
            loader:'postcss-loader',
            options:{
              ident: 'postcss',
              plugins:[
                autoprefixer({
                  browsers:['ie >= 8', 'last 4 version']
                })
              ]
            }
          },

          {
            loader:'sass-loader',
            options:{
              sourceMap:true,
              data:'$mode:' + mode + ';',
            }
          }

        ]
      },


      // CSS
      {
        test:/\.css$/,
        use:[

          {
            loader:css.loader,
            options:{
              sourceMap:true,
            }
          },

          {
            loader:'css-loader',
            options:{
              sourceMap:true,
              minimize: mode,
            }
          }

        ]

      },

      // IMG
      {
        test:/\.(png|jpg|gif|svg)$/,
        exclude:/fonts/,
        use:{
          loader:'file-loader',
          options:{
            name:'[name].[ext]',
            outputPath:'images/',
          }
        }
      },

      // FONTS
      {
        test:/\.woff($|\?)|\.woff2($|\?)|\.ttf($|\?)|\.eot($|\?)|\.svg($|\?)/,
        exclude:/images/,
        use:[
          {
            loader:'file-loader',
            options:{
              name:'fonts/[name].[ext]',
              publicPath:'../',
            }
          }
        ]
      },

    ]

  },

  plugins:[
    new clean('build/',{
      "allowExternal": false,
      "verbose":false
    }),
    new css({filename:'css/[name].css'}),
    new webpack.ProvidePlugin({
      $:'jquery',
      jQuery:'jquery',
      'window.jQuery': 'jquery',
      Popper: ['popper.js', 'default']
    }),
    new notify({
      "title":"Project",
      "suppressSuccess":true
    })
  ],

  resolve:{
    modules:[
      'node_modules',
      'src/components',
      'src/vendor',
    ],
    extensions:['.js','.pug']
  },

  devtool:mode?'none':'inline-source-map',

  devServer:{
    contentBase:path.resolve(__dirname, 'build'),
    compress:true,
    port:8080
  }

}

function checkMode(argv, check){
  return argv.slice(7,argv.length) === check;
}
  • Вопрос задан
  • 309 просмотров
Подписаться 2 Простой Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы