M
M
myskypesla2018-11-15 10:30:07
webpack
myskypesla, 2018-11-15 10:30:07

Why doesn't background url work with svg files in webpack?

My config:

const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const path = require('path');

const resolve = dir => path.join(__dirname, '..', dir);

module.exports = {
  entry: {
    app: './src/index.js',
  },
  output: {
    path: resolve('dist'),
    filename: 'js/[name].[hash].js',
    publicPath: process.env.NODE_ENV === 'production' ? '/' : '/',
  },
  optimization: {
    splitChunks: {
      cacheGroups: {
        vendor: {
          chunks:'initial',
          name: 'vendor',
          test: 'vendor',
          enforce: true,
        },
      },
    },
  },
  resolve: {
    extensions: ['.js', '.json'],
  },
  module: {
    rules: [
      {
        test: /\.jsx?$/,
        exclude: /node_modules/,
        enforce: 'pre',
        use: {
          loader: 'eslint-loader',
        },
      },
      {
        test: /\.jsx?$/,
        exclude: /node_modules/,
        use: {
          loader: 'babel-loader',
        },
      },
      {
        test: /\.html$/,
        exclude: /node_modules/,
        use: {
          loader: 'html-loader',
        },
      },
      {
        test: /\.(sa|sc|c)ss$/,
        exclude: /node_modules/,
        use: [
          MiniCssExtractPlugin.loader,
          {
            loader: 'css-loader',
            options: {
              sourceMap: true,
            },
          },
          {
            loader: 'postcss-loader',
            options: {
              sourceMap: true,
            },
          },
          {
            loader: 'sass-loader',
            options: {
              sourceMap: true,
            },
          },
        ],
      },
      {
        test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
        exclude: /node_modules/,
        loader: 'url-loader',
        options: {
          limit: 10000,
          name: '[hash]-[name].[ext]',
        },
      },
      {
        test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/,
        exclude: /node_modules/,
        loader: 'url-loader',
        options: {
          limit: 10000,
          name: '[hash]-[name].[ext]'
        },
      },
      {
        test: /\.(woff2?|eot|ttf|otf|svg)(\?.*)?$/,
        exclude: /node_modules/,
        loader: 'file-loader',
        options: {
          limit: 10000,
          name: '[name]-[hash].[ext]',
        },
      },
    ],
  },
};

Question: with this config, import inside jsx works fine, both in dev mode and in prod. But the background url does not work, that is, the SVG image is not visible, everything is fine with PNG.
In css I write like this:
.icon {
  width: 4.2rem;
  height: 5.3rem;
  background: url('../img/icon.svg') left top no-repeat;
  background-size: contain;
}

And instead of an icon, this is what happens:
background: url() left top no-repeat

The project structure is as follows:
project
--public
----index.html
--src
----assets
------img
--------icon.svg
------scss
--------icons.scss (тут и пишу)
----components
----views
----...

Answer the question

In order to leave comments, you need to log in

2 answer(s)
A
alexhovansky, 2018-11-20
@alexhovansky

Я не знаю как починить вашу проблему, но на вашем месте я бы воспользовался copy-webpack-plugin и копировал бы папку с отдельными изображениями, в результате у вас в build появится папка с файлами

A
Ascanos, 2021-03-22
@Ascanos

Если не устареет то вот
https://www.npmjs.com/package/image-webpack-loader
Мне помогло

Didn't find what you were looking for?

Ask your question

Ask a Question

731 491 924 answers to any question