【发布时间】:2019-05-08 06:47:13
【问题描述】:
我有这个webpack.config:
const UglifyJsPlugin = require("uglifyjs-webpack-plugin");
const HtmlWebpackPlugin = require('html-webpack-plugin');
const HtmlWebpackInlineStylePlugin = require('html-webpack-inline-style-plugin');
const path = require('path');
module.exports = {
mode: 'production',
entry: {
main: [
'./src/scss/main.scss'
]
},
output: {
path: path.resolve(__dirname, './dist'),
publicPath: '',
filename: 'js/[name].js'
},
optimization: {
minimizer: [
new UglifyJsPlugin({
cache: true,
parallel: true,
sourceMap: true
})
]
},
module: {
rules: [
{
test: /\.scss$/,
use: [
'css-loader',
'sass-loader',
]
},
// ... other stuffs for images
]
},
plugins: [
new HtmlWebpackPlugin({
template: './src/main.html',
filename: 'main.html'
}),
new HtmlWebpackInlineStylePlugin()
]
};
我试过这个配置,但效果不好,因为 CSS 代码生成到 main.css 文件中。
但如果我将 CSS 代码作为<style> 直接写入<head> 标签,它就可以工作。
如何设置 webpack 以将 Sass 文件中的 CSS 代码作为内联 CSS 放入 HTML?
或者有没有勾选将 CSS 首先放入 <head>,然后 html-webpack-inline-style-plugin 插件可以解析它?
【问题讨论】: