javascript - 将捆绑的 css 移动到不同的目录会将 URL 前缀 ../更改为 only/

标签 javascript webpack webpack-file-loader

我正在尝试为多页面网站(不是 SPA)设置 webpack 配置(这是我第一次使用 webpack) 。到目前为止一切都很顺利,但是 css 中元素的 url 路径没有指向正确的目的地。

我正在使用extract-text-webpack-plugin创建单独的 css 包和 file-loader加载图像。

问题是当构建过程完成时,CSS 中的相对 URL 例如 ../assets/images/<hash>.png更改为assets/images/<hash>.png 因此图像不会显示在页面上。但是,通过 img 标签放置在 html 页面中的其他图像加载 assets/images/<hash>.png作为来源。

因此,我的问题是

  • 如何保留 css 文件内的相对路径?

我真的需要一些帮助,因为这是我第一次使用 webpack,并且花了几个不眠之夜安静地弄清楚了这么多。 :(

Webpack.config.js

const path = require('path');
const ExtractTextPlugin = require("extract-text-webpack-plugin");
const extractCSS = new ExtractTextPlugin("css/[name].styles.min.css");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const CleanWebpackPlugin = require("clean-webpack-plugin");

const entryPoints = require("./app");

module.exports = {
    entry: entryPoints,
    output: {
        path: path.resolve(__dirname + "/dist"),
        filename: "js/[name].bundle.min.js",
    },
    module: {
        rules: [
            {
                test: /\.js$/,
                use: [
                    {
                        loader: "babel-loader",
                        options: {
                            presets: ["es2015"]
                        }
                    }
                ],
                exclude: /node_modules/
            },
            {
                test: /\.css$/,
                use: extractCSS.extract({
                    fallback: "style-loader",
                    use: [
                        {
                            loader: "css-loader",
                            options: {
                                minimize: true,
                                sourceMap: true
                            }
                        },
                        "postcss-loader"
                    ]
                })
            },
            {
                test: /\.html$/,
                use: ["html-loader"]
            },
            {
                test: /\.(svg|gif|jpg|png)$/,
                use: [
                    {
                        loader: "file-loader",
                        options: {
                            outputPath: "assets/images/",
                            publicPath: "assets/images/"
                        }
                    }
                ]
            }
        ]
    },
    plugins: [
        extractCSS,
        new HtmlWebpackPlugin({
            filename: "index.html",
            template: "src/index.html",
            chunks: ["index"]
        }),
        new HtmlWebpackPlugin({
            filename: "page2.html",
            template: "src/page2.html",
            chunks: ["page2"]
        }),
        new CleanWebpackPlugin(["dist"])
    ]
}; 

我的项目结构如下:

Project
|
|__ dist
|     |__ assets
|     |       |__images
|     |             |__ image1-hash
|     |             |__ image2-hash
|     |             |__ image3-hash
|     |
|     |__ css
|     |    |_ index.styles.min.css
|     |    |_ page2.styles.min.css
|     |
|     |__ js
|     |    |_ index.bundle.min.js
|     |    |_ page2.bundle.min.js
|     |
|     |__ index.html
|     |__ page2.html
|
|__ node_modules
|

最佳答案

尝试这个,作为解决方法,替换

const extractCSS = new ExtractTextPlugin("css/[name].styles.min.css");

const extractCSS = new ExtractTextPlugin("[name].styles.min.css");
<小时/>

最终解决方案:

        {
            test: /\.(svg|gif|jpg|png)$/,
            use: [
                {
                    loader: "file-loader",
                    options: {
                        outputPath: "assets/images/",
                        publicPath: "/assets/images/" // <- use absolute path
                    }
                }
            ]
        }

关于javascript - 将捆绑的 css 移动到不同的目录会将 URL 前缀 ../更改为 only/,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50470421/

相关文章:

javascript - 如何使用 jquery 将类添加到 bootstrap 表中的 td 标记

reactjs - 未捕获的类型错误 : Cannot read property 'mountComponent' of undefined error when running create-react-app build version

css - 如何从 Vue 组件中的 node_modules 导入 css 文件

javascript - Webpack 文件加载器不加载具有复杂路径的文件

Webpack 文件加载器不复制文件

javascript - 如何在鼠标单击时设置可拖动事件?

javascript - 在 JointJs 中的 validateConnection 之上添加 debounce

javascript - 在 ng-repeat AngularJS 中更改点击元素的工具提示

javascript - webpack 导出默认有效,而导出对象则无效

node.js - 如何使用 Node 和 Webpack 正确加载照片?