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

Почему webpack отталкивается от папки css, а не от src, при импорте стилей?

Использую sass + webpack
Подключают background по пути ./src/img/background_main_1.svg.

.header
  &__container
    background-image: url('./src/img/background_main_1.svg')
    background-repeat: no-repeat
    background-position-x: right
    background-position-y: 40px
    padding-bottom: 120px


Но webpack выдает ошибку, будто
Error: Can't resolve './src/css/background_main_1.svg' in 'C:\basharin_andrej\tit_landing\src\css'
он ищет картинку в src/css, а не в src.
Почему так происходит.

Указывал aliasы, но тоже не работает.
Может кто сталкивался с этим ?

60ba50b0e2b8b109722217.png

Вот webpack.config
const path = require('path')
const MiniCssExtractPlugin = require('mini-css-extract-plugin')
const PATHS = require('./webpack.config/paths')
const getPlugins = require('./webpack.config/getPlugins')
const getEntryPoint = require('./webpack.config/getEntryPoint')


module.exports = {
    entry: getEntryPoint(),
    output: {
        path: path.resolve(__dirname, 'docs'),
        filename: '[name].[hash].js'
    },
    mode: 'development',
    context: path.resolve(__dirname, 'src'),
    devtool: "inline-source-map",
    devServer: {
        port: 3000
    },
    resolve: {
        alias: {
            '@img': path.resolve(__dirname, PATHS.img),
            '@js': path.resolve(__dirname, PATHS.js),
            '@css': path.resolve(__dirname, PATHS.css),
            '@modules': path.resolve(__dirname, PATHS.modules)
        },
    },
    plugins: getPlugins(),
    module: {
        rules: [
            {test: /\.css$/},
            {test: /\.s[ac]ss$/,
                use: [
                    {loader: MiniCssExtractPlugin.loader},
                    'css-loader',
                    'sass-loader'
                ]
            },
            {
                test: /\.(svg|png|gif)$/,
                options: {
                    name: '[name].[ext]',
                    outputPath: '../src/img'
                },
                loader: 'file-loader'
            },
            {
                test: /\.pug$/,
                loader: 'pug-loader',
                options: {
                    pretty: true
                }
            }
        ]
    }
}
  • Вопрос задан
  • 107 просмотров
Подписаться 1 Простой 1 комментарий
Пригласить эксперта
Ответы на вопрос 1
@sergiodev
Потому что путь начинается на ./ поэтому он и ищет относительно текущей директории, т.е директории текущего файла, коей является css

Советую поменять ./src/img на src/img или ../img
Ответ написан
Комментировать
Ваш ответ на вопрос

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

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