WebPack如何把所有的css文件放到一个css文件中

问题描述 投票:0回答:2

我是 WebPack 的新手,我希望能够获取一个 CSS 文件目录(.app/styles/[css 文件...])并将它们输出到一个 CSS 文件(dist/styles.css)中。

目前,所有的 JavaScript 文件都被编译成一个单独的“index_bundle.js”文件,这是完美的,但我想为我的 CSS 文件实现同样的效果。

经过大量“谷歌搜索”后,我发现 WebPack 的 ExtractTextPlugin 应该能够帮助解决这个问题,但这只适用于添加到“entry”属性的一个 CSS 文件(例如:entry: {style: " ./app/styles/style.css"}) 然后作为链接标记添加到 html 的头部,这很好,但我希望我所有的 css 文件都进入一个 styles.css 文件,然后在html的头部作为链接。

我当前的 WebPack 配置如下所示:

var HtmlWebpackPlugin = require('html-webpack-plugin');
var HtmlWebpackPluginConfig = new HtmlWebpackPlugin({
    template: __dirname + '/app/index.html',
    filename: 'index.html',
    inject: 'body'
});

var ExtractTextPlugin = require('extract-text-webpack-plugin');
var ExtractTextPluginConfig = new ExtractTextPlugin(
    "styles.css", 
    {
        allChunks: false
    }
);

module.exports = {
    entry: {
        index: "./app/index.js"//,
        //styles: "./app/styles/style1.css" // I don't want one file, I want to use a directory eg: "./app/styles/"
    },
    output: {
        path: __dirname + '/dist',
        filename: 'index_bundle.js'
    },
    module: {
        loaders: [
            {
                test: /\.js$/, 
                exclude: /node_modules/, 
                loader: 'babel-loader'
            },
            { 
                test: /\.css$/, 
                loader: ExtractTextPlugin.extract("style-loader", "css-loader")
            }
        ]
    },
    plugins: [
        HtmlWebpackPluginConfig,
        ExtractTextPluginConfig
    ]
}

有人可以指出我正确的方向吗?即使它是另一个插件或不同的方法。任何帮助将不胜感激!

编辑: 我的新 WebPack 配置如下所示:

var HtmlWebpackPlugin = require('html-webpack-plugin');
var HtmlWebpackPluginConfig = new HtmlWebpackPlugin({
    template: __dirname + '/app/index.html',
    filename: 'index.html',
    inject: 'body'
});

var ExtractTextPlugin = require('extract-text-webpack-plugin');
var ExtractTextPluginConfig = new ExtractTextPlugin(
    "index_bundle.css"
);

module.exports = {
    entry: [
        './app/index.js',
        './app/index.css'
    ],
    output: {
        path: __dirname + '/dist',
        filename: 'index_bundle.js'
    },
    module: {
        preloaders: [
            {
                test: /\.css/,
                exclude: /styles/, 
                loader: 'import-glob-loader'
            }
        ],
        loaders: [
            {
                test: /\.js$/, 
                exclude: /node_modules/, 
                loader: 'babel-loader'
            },
            { 
                test: /styles\.css$/, 
                loader: ExtractTextPlugin.extract("style-loader", "css-loader")
            },
            { 
                test: /\.json$/, 
                loader: 'json' 
            }
        ]
    },
    devServer: {
        historyApiFallback: true
    },
    plugins: [
        HtmlWebpackPluginConfig,
        ExtractTextPluginConfig
    ]
}
javascript css webpack html-webpack-plugin
2个回答
9
投票

好吧,这似乎是一个驼峰问题。

Davin Tryon 的帮助下,我能够解决我的问题 - 谢谢!

如果你看:https://www.npmjs.com/package/import-glob-loader 他们有以下内容:

preloaders: [{
    test: /\.scss/,
    loader: 'import-glob-loader'
}]

应该是:

preLoaders: [{
    test: /\.scss/,
    loader: 'import-glob-loader'
}]

所以最后,我的整个 webpack.config.json 看起来是这样的:

var HtmlWebpackPlugin = require('html-webpack-plugin');
var HtmlWebpackPluginConfig = new HtmlWebpackPlugin({
    template: __dirname + '/app/index.html',
    filename: 'index.html',
    inject: 'body'
});

var ExtractTextPlugin = require('extract-text-webpack-plugin');
var ExtractTextPluginConfig = new ExtractTextPlugin(
    "index_bundle.css"
);

module.exports = {
    entry: [
        './app/index.js',
        './app/index.css'
    ],
    output: {
        path: __dirname + '/dist',
        filename: 'index_bundle.js'
    },
    module: {
        preLoaders: [
            {
                test: /\.css$/,
                exclude: /styles/, 
                loader: 'import-glob-loader'
            }
        ],
        loaders: [
            {
                test: /\.js$/, 
                exclude: /node_modules/, 
                loader: 'babel-loader'
            },
            { 
                test: /\.css$/, 
                loader: ExtractTextPlugin.extract("style-loader", "css-loader")
            },
            { 
                test: /\.json$/, 
                loader: 'json' 
            }
        ]
    },
    devServer: {
        historyApiFallback: true
    },
    plugins: [
        HtmlWebpackPluginConfig,
        ExtractTextPluginConfig
    ]
}

我的 index.css 文件看起来像这样:

@import './styles/**/*';

这对我有用,我得到了一个 css 输出文件“index_bundle.css”。样式和脚本也会自动注入到 html 模板中。

index.html 注入前:

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Admin - Login</title>
        <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/latest/css/bootstrap.min.css"/>
    </head>
    <body>
        <div id="app"></div>
    </body>
</html>

index.html 在 /dist 文件夹中注入后:

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Admin - Login</title>
        <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/latest/css/bootstrap.min.css"/>
    <link href="index_bundle.css" rel="stylesheet"></head>
    <body>
        <div id="app"></div>
    <script type="text/javascript" src="index_bundle.js"></script></body>
</html>

0
投票

终于找到答案了。因为 webpack.config.js 由于一些愚蠢的错误而无法工作。我的问题是文件名不对

© www.soinside.com 2019 - 2024. All rights reserved.