webpack使用ExtractTextPlugin+css-loader时类名并没有打包成哈希值?

var webpack = require('webpack');
var HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
module.exports = {

entry: __dirname + "/src/main.js", //入口文件
output: {
    path: __dirname + "/dist", //打包后导出文件夹
    filename: "bundle.js" //导出的文件名
},

// devtool: 'cheap-module-source-map',

module: {
    loaders: [{
            test: /\.js$/,
            exclude: /node_modules/,
            loader: 'babel-loader',
            query: {
                presets: ['es2015', 'react']
            }
        },
        {
            test: /\.vue$/,
            loader: 'vue-loader'
        },
        {
            test: /\.css$/,
            use: ExtractTextPlugin.extract({
                fallback: "style-loader",
                use: [{
                    loader: "css-loader",
                    options: {
                        modules: true//在这里我设置为true了,可是实际上css文件里的样式名变为哈希值了,可是打包后的html文件引用的地方却没有打包成哈希值,导致我应用不上样式
                    }
                }, {
                    loader: "postcss-loader"
                }]
            })
        }, {
            test: /\.(gif|png|jpg|svg)$/,
            use: [{
                loader: 'url-loader',
                options: {
                    limit: 1024,
                    name: 'images/[name]-[hash:8].[ext]'
                }
            }]
        }
    ]
},
resolve: {
    alias: {
        'vue$': 'vue/dist/vue.js'
    }
},
devServer: {
    contentBase: "./dist", //本地服务器所加载的页面所在的目录
    stats: {
        colors: true
    }, 
    historyApiFallback: true, 
    inline: true,
    hot: true
},
plugins: [
    new webpack.BannerPlugin('版权所有,翻版必究'),
    new HtmlWebpackPlugin({
        template: __dirname + "/index.html" 
    }),
    new ExtractTextPlugin("style.css"),
    new webpack.HotModuleReplacementPlugin() 
]

}

我把上述的modules: true改为false以后,虽然样式名没有变为哈希值,但是能应用上样式了,说明我的css文件是引用到了,引用没有问题,求大神告知,我哪里配置错误了,万分感谢!
这是打包后的css文件

这是html,因为没有变成哈希值,故没有应用上样式

阅读 4.5k
1 个回答

设置css-loader modules模块化之后
引入css的请按如下方式

const styles = require("你的样式表路径")
或者
import styles from '你的样式表路径'; //  “styles” 你可以随便改一个词 

css:
    sectionOne:{color:#red;}
html    
    <div className={styles.sectionOne}></div>
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题