Почему фоновый URL не работает с файлами SVG в веб-пакете? - PullRequest
0 голосов
/ 16 ноября 2018

webpack.base.config.js:

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]',
        },
      },
    ],
  },
};

Я пишу в CSS так:

.icon {
  width: 4.2rem;
  height: 5.3rem;
  background: url('../img/icon.svg') left top no-repeat;
  background-size: contain;
}

И вместо значка эточто происходит:

background: url(data:image/svg+xml;base64,bW9kdWxlLmV4cG9ydHMgPSBfX3dlYnBhY2tfcHVibGljX3BhdGhfXyArICJpY29uLWRvYy1hNjk0NTdkY2IzZWQ1OWVhZmZhZjE4MDA3MTkwNWI1Yi5zdmciOw==) left top no-repeat

Структура проекта выглядит следующим образом:

project
--public
----index.html
--src
----assets
------img
--------icon.svg
------scss
--------icons.scss (тут и пишу)
----components
----views
----...

Вопрос: с этим конфигом, импорт внутри jsx работает нормально, оба режима разработкии в продаже.Но не работает фоновый URL, то есть картинка SVG не видна, с PNG все нормально.

1 Ответ

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

В этом коде вы говорите веб-пакету преобразовать svg изображения в base64 с модулем url-loader

{
        test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
        exclude: /node_modules/,
        loader: 'url-loader',
        options: {
          limit: 10000,
          name: '[hash]-[name].[ext]',
        },
      }

Это должно действительно работать ...

Я предлагаю вам попробовать следующее:

Попробуйте вставить svg прямо в html, где должен быть значок.Сделайте это так, чтобы вы могли повторно использовать его, например, создать компонент значка, который находится в конце этой формы, в DOM:

, например

<div class="my-icon">
  <svg><path/></svg>
</div>

Если вы вставите его как HTML, он будет работать

...