babel-plugin-реагировать-css-modules не поддерживает фоновые изображения - PullRequest
0 голосов
/ 10 декабря 2018

После использования css-модулей фоновое изображение в scss не будет работать.

Пожалуйста, как правильно его настроить?

репо: https://github.com/pdsuwwz/Antd-app

Ошибка:

ERROR in ./src/script/components/redux-test/style.scss
Module build failed (from ./node_modules/mini-css-extract-plugin/dist/loader.js):
ModuleNotFoundError: Module not found: Error: Can't resolve 'assets/black-coffee.png' in '/Users/admin/Documents/zhike/github/myRepository/Antd-test/Antd-app/src/script/components/redux-test'
    at factory.create (/Users/admin/Documents/zhike/github/myRepository/Antd-test/Antd-app/node_modules/webpack/lib/Compilation.js:821:10)
    at factory (/Users/admin/Documents/zhike/github/myRepository/Antd-test/Antd-app/node_modules/webpack/lib/NormalModuleFactory.js:397:22)
    at resolver (/Users/admin/Documents/zhike/github/myRepository/Antd-test/Antd-app/node_modules/webpack/lib/NormalModuleFactory.js:130:21)
    at asyncLib.parallel (/Users/admin/Documents/zhike/github/myRepository/Antd-test/Antd-app/node_modules/webpack/lib/NormalModuleFactory.js:224:22)

.babelrc:

...
["babel-plugin-react-css-modules", {
  "generateScopedName": "[name]_[local]_[hash:base64:5]",
  "webpackHotModuleReloading": true,
  "filetypes": {
    ".scss": {
      "syntax": "postcss-scss"
    }
  }
}]
...

scss:

.test-relativeimg{
  width: 200px;
  height: 200px;
  background-image: url("./assets/black-coffee.png");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

webpack

{
  test: /\.scss/,
  use: [MiniCssExtractPlugin.loader, "css-loader?modules&importLoaders=1&localIdentName=[name]_[local]_[hash:base64:5]", {
    loader: 'postcss-loader',
    options: {
      ident: 'postcss',
      sourceMap: true,
      config: {
        path: resolve('postcss.config.js')
      }
    },
  },
  "sass-loader"],
  exclude: resolve('node_modules'),
  include: resolve('src')
}

postcss.config.js

module.exports = {
  plugins: [require("autoprefixer")({
    browsers: ['last 2 versions']
  }), require("cssnano")()]
}

1 Ответ

0 голосов
/ 13 декабря 2018

Проблема в том, что Webpack нужен загрузчик для файла png.

Вам нужен url-loader ||загрузчик файлов для загрузки изображений / ресурсов в ваш пакет

Дополнительная информация

...