Как обрабатывать встроенные CSS-атрибуты / URL с помощью Webpack? - PullRequest
0 голосов
/ 05 июня 2019

Я впервые использую Webpack и могу обрабатывать внешние CSS и JS-файлы по мере необходимости.Я также могу загружать изображения из моих HTML-файлов, используя теги img .Теперь я хотел бы загрузить фоновые изображения следующим образом:

src / index.html

<div style="background-image: url('img/item.png');" ></div>

Приведенный выше код не работает и изображение недаже добавлен в мою папку dist / images .Вот моя точка входа.

src / index.js

import './js/home.js';
import './css/home.css';
require('./index.html')

Вот мой файл конфигурации Webpack:

webpack.conf.js

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

module.exports = {
    mode: 'development',
    entry: {
        home: './src/index.js'
    },
    output: {
        path: path.resolve(__dirname, 'dist'),
        filename: 'js/[name].js'
    },
    plugins: [
        new MiniCssExtractPlugin({
            publicPath: path.resolve(__dirname, 'dist'),
            filename: 'css/[name].css',
        }),
        new webpack.HotModuleReplacementPlugin()
    ],
    module: {
        rules: [
            {
                test: /\.css$/,
                use: [
                    'css-hot-loader',
                    {
                        loader: MiniCssExtractPlugin.loader,
                        options: {
                            publicPath: path.resolve(__dirname, 'dist/css')
                        }
                    },
                    'css-loader'
                ]
            },
            {
                test: /\.html$/,
                use: ['html-loader']
            },
            {
                test: /\.(png|svg|jpg|gif)$/,
                use: [
                    {
                        loader: 'file-loader',
                        options: {
                            name:'img/[name].[ext]',
                            publicPath: '/'
                        }
                    }
                ]
            },
            {
                test: /\.(ttf|eot|svg|woff|woff2|otf)$/,
                use:[
                    {
                        loader: 'file-loader',
                        options: {
                            name:'fonts/[name].otf',
                            publicPath: '/'
                        }
                    }
                ]
            }
        ]
    },
    devServer: {
        contentBase: './dist',
        hot: true,
        watchContentBase: true
    }
};

Каков правильный подход к этому?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...