webpack css-loader: не удается загрузить файл png, указанный как url ​​(«путь») внутри файла css

Я делаю свои первые шаги в использовании веб-пакета... пока не очень успешно. В моем файле .css есть фоновое изображение, определенное с помощью URL-адреса:

background-image: url("patterns/header-profile.png");

Приложение эффектно вылетает при запуске с этой ошибкой:

ERROR in ./~/css-loader?"modules":true,"sourceMap":true,"importLoaders":1,"localIdentName":"[local]__[hash:base64:5]"}!./~/postcss-loader!./src/assets/css/in
spinia.css

Module not found: Error: Can't resolve 'patterns/header-profile.png' in 'C:\----  absolute path  ---\src\assets\css'

Прежде всего, это структура моего проекта:

./src/
  --> assets
        --> patterns
              --> header-profile.png
        --> mystyle.css  // <-- sos: this is where background img is defined
--> index.html
--> index.tsx

Во-вторых, это мой webpack.config.json:

var webpack = require('webpack');
var path = require('path');

// variables
var isProduction = process.argv.indexOf('-p') >= 0;
var sourcePath = path.join(__dirname, './src');
var outPath = path.join(__dirname, './dist');

// plugins
var HtmlWebpackPlugin = require('html-webpack-plugin');
var ExtractTextPlugin = require('extract-text-webpack-plugin');

module.exports = {
  context: sourcePath,
  entry: {
    main: './index.tsx',
    vendor: [
      'react',
      'react-dom',
      'react-redux',
      'react-router',
      'react-router-redux',
      'redux'
    ]
  },
  output: {
    path: outPath,
    publicPath: './',
    filename: 'bundle.js',
  },
  target: 'web',
  resolve: {
    extensions: ['.js', '.ts', '.tsx'],
    // Fix webpack's default behavior to not load packages with jsnext:main module
    // https://github.com/Microsoft/TypeScript/issues/11677 
    mainFields: ['main']
  },
  module: {
    loaders: [
      // .ts, .tsx
      {
        test: /\.tsx?$/,
        loader: isProduction
          ? 'awesome-typescript-loader?module=es6'
          : [
            'react-hot-loader',
            'awesome-typescript-loader'
          ]
      },
      // css 
      {
        test: /\.css$/,
        loader: ExtractTextPlugin.extract({
          fallback: 'style-loader',
          publicPath: './',
          loader: [
            {
              loader: 'css-loader',
              query: {
                modules: true,
                sourceMap: !isProduction,
                importLoaders: 1,
                localIdentName: '[local]__[hash:base64:5]'
              }
            },
            {
              loader: 'postcss-loader'
            }
          ]
        })
      },
      // static assets 
      { test: /\.html$/, loader: 'html-loader' },
      { test: /\.png$/, loader: "url-loader?limit=10000" },
      { test: /\.jpg$/, loader:  'file-loader' },
    ],
  },
  plugins: [
    new webpack.LoaderOptionsPlugin({
      options: {
        context: sourcePath,
        postcss: [
          require('postcss-import')({ addDependencyTo: webpack }),
          require('postcss-url')(),
          require('postcss-cssnext')(),
          require('postcss-reporter')(),
          require('postcss-browser-reporter')({ disabled: isProduction }),
        ]
      }
    }),
    new webpack.optimize.CommonsChunkPlugin({
      name: 'vendor',
      filename: 'vendor.bundle.js',
      minChunks: Infinity
    }),
    new webpack.optimize.AggressiveMergingPlugin(),
    new ExtractTextPlugin({
      filename: 'styles.css',
      disable: !isProduction
    }),
    new HtmlWebpackPlugin({
      template: 'index.html'
    })
  ],
  devServer: {
    contentBase: sourcePath,
    hot: true,
    stats: {
      warnings: false
    },
  },
  node: {
    // workaround for webpack-dev-server issue 
    // https://github.com/webpack/webpack-dev-server/issues/60#issuecomment-103411179
    fs: 'empty',
    net: 'empty'
  }
};

И, наконец, вот как я требую mystyle.css в индексном файле js:

require('/assets/css/inspinia.css');

Я просмотрел stackoverflow, github и google. Я видел, что другие люди сталкивались с подобными проблемами. Но я не понимаю различные решения, которые они применяли (я новичок в веб-пакете).

Любая помощь будет принята с благодарностью.


person TheSoul    schedule 20.02.2017    source источник
comment
Module not found: Error: Can't resolve 'patterns/header-profile.png' in 'C:\---- absolute path ---\src\assets\css' - Изображение находится в папке css? Структура проекта не показывает это так...   -  person Quotidian    schedule 20.02.2017
comment
Да, это в папке css...   -  person TheSoul    schedule 20.02.2017


Ответы (1)


Вот как я исправил эту проблему, не понимая, почему она решила мою проблему (просто изменив свойства...).

Прежде всего, в моем файле webpack.config.json я убедился, что этот publicPath является абсолютным ('/'), а не относительным ('./')

{
  output:{
     publicPath: '/'
  }
}

Во-вторых, в моем index.tsx, где мне нужен mystyle.css, я убедился, что это относительный путь:

require('./assets/css/mystyle.css')

И, наконец, внутри mystyle.css, где я ссылаюсь на свои изображения, я убедился, что это абсолютный путь (...безумие...). Так, например, я бы:

background: url("/patterns/header-profile.png")

И это волшебным образом работает!

Может ли кто-нибудь объяснить, в чем логика этой конфигурации, это помогло бы мне понять, как работает веб-пакет, особенно когда речь идет о файлах css, ресурсах изображений и абсолютных/относительных путях.

person TheSoul    schedule 20.02.2017