2 回答

TA貢獻(xiàn)1757條經(jīng)驗(yàn) 獲得超7個贊
這就是我在這里所做的
首先,我將使用 webpack 中的此設(shè)置將我的 scss 轉(zhuǎn)換為 css 文件
module: {
rules: [{
test: /\.scss$/,
use: [
'style-loader',
MiniCssExtractPlugin.loader,
{
loader: "css-loader",
options: {
minimize: true,
sourceMap: true
}
},
{
loader: "sass-loader"
}
]
}
]
}
然后我使用 webpack-shell-plugin 運(yùn)行 postcss 命令來縮小 css 文件。(獎金我還使用壓縮插件添加 gzip 將 css 轉(zhuǎn)換為 gzip)
plugins: [
new CompressionPlugin({
test: /\.(js|css)/
}),
new WebpackShellPlugin({
onBuildStart: ['echo "Starting postcss command"'],
onBuildEnd: ['postcss --dir wwwroot/dist wwwroot/dist/*.css']
})
],

TA貢獻(xiàn)1841條經(jīng)驗(yàn) 獲得超3個贊
下面是一個對我有用的最小示例:
包.json:
{
…
"devDependencies": {
"css-loader": "^3.2.0",
"mini-css-extract-plugin": "^0.8.0",
"node-sass": "^4.12.0",
"optimize-css-assets-webpack-plugin": "^5.0.3",
"sass-loader": "^8.0.0",
"webpack": "^4.40.2",
"webpack-cli": "^3.3.9"
}
}
webpack.config.js:
const path = require("path");
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const OptimizeCssAssetsPlugin = require('optimize-css-assets-webpack-plugin');
module.exports = {
…
module: {
rules: [
{ // CSS assets remaining in the pipeline (e.g. frameworks)
test: /\.css$/,
use: [
"style-loader", // or e.g. "vue-style-loader" etc. (optional)
MiniCssExtractPlugin.loader,
"css-loader"
]
},
{ // SCSS
test: /\.scss$/,
use: [
"style-loader" // (optional)
MiniCssExtractPlugin.loader,
"css-loader",
"sass-loader"
]
}
]
},
// Plugins
plugins: [
new MiniCssExtractPlugin({
filename: "./css/my-style.css" // relative to `output.path` by default
}),
new OptimizeCssAssetsPlugin() // construction suffices, no additional calls needed
]
};
該node-sass模塊已經(jīng)輸出縮小的 CSS,所以如果您知道在您的項(xiàng)目中不會遇到任何原始 CSS,您可以去掉OptimizeCssAssetsPlugin.
添加回答
舉報(bào)