【问题标题】:Webpack 4: file-loader not loading assets in .css or .scss filesWebpack 4:文件加载器不加载 .css 或 .scss 文件中的资产
【发布时间】:2019-06-15 16:42:19
【问题描述】:

我正在尝试移动我的一个 .scss 文件中使用的资产(图像和字体),但它们似乎被忽略了:

这是我的 .scss 文件:

@font-face {
    font-family: 'myfont';
    src: url('../../assets/fonts/myfont.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
}

body {
    color: red;
    font-family: 'myfont';
    background: url('../../assets/images/bg.jpg');
}

这是我的 webpack.config.js:

const path = require('path');
const { CheckerPlugin } = require('awesome-typescript-loader');
const MiniCssExtractPlugin = require("mini-css-extract-plugin");

module.exports = {
    target: 'node',
    entry: path.resolve(__dirname, 'server.tsx'),
    output: {
        filename: 'server_bundle.js',
        path: path.resolve(__dirname, 'build'),
        publicPath: '/build'
    },
    resolve: {
        extensions: ['.ts', '.tsx', '.js', '.jsx']
    },
    module: {
        rules: [{
                test: /\.(tsx|ts)?$/,
                loader: 'awesome-typescript-loader',
                options: {
                    jsx: 'react'
                }
            },
            {
                test: /\.(scss|sass|css)$/,                
                use: [
                    MiniCssExtractPlugin.loader,
                    { loader: 'css-loader', options: { url: false, sourceMap: true } },
                    { loader: 'sass-loader', options: { sourceMap: true } },                    
                ]
            },
            {
                test: /\.(png|svg|jpg|jpeg|gif)$/,
                loader: 'file-loader',
                options: { outputPath: 'public/images' }
            },
            {
                test: /\.(woff|woff2|eot|ttf|otf)$/,
                loader: 'file-loader',
                options: { outputPath: 'public/fonts' }
            }
        ]
    },
    plugins: [
        new CheckerPlugin(),
        new MiniCssExtractPlugin({
            filename: 'public/styles_bundle.css',
            chunkFilename: "public/styles/[id].css"
        })
    ]
}

为什么 Webpack 不处理字体和图像?

【问题讨论】:

标签: css webpack webpack-file-loader


【解决方案1】:

在 webpack 4.32.2 中测试了 file-loader 和 url-loader。

file-loader 仅加载在 .tsx 文件中导入的文件。 url-loader 不适合我。

最后,我发现的是 copy-webpack-plugin

【讨论】:

    猜你喜欢
    • 2019-05-23
    • 1970-01-01
    • 1970-01-01
    • 2018-12-21
    • 2018-06-24
    • 2018-05-15
    • 1970-01-01
    • 2018-05-21
    • 2018-03-03
    相关资源
    最近更新 更多