【发布时间】:2020-01-10 18:39:11
【问题描述】:
我有一个 Wordpress 主题,我正在从 gulp 迁移到 webpack。我有一段时间不编译 SASS 文件。它可以很好地查看和编译 JS 文件,但 SASS 文件不会编译成 CSS。这是我的 webpack-config.js
const path = require('path');
const UglifyJSPlugin = require('uglifyjs-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
module.exports = {
entry: ['./js/app.js', './sass/style.scss'],
plugins: [
new UglifyJSPlugin(),
new MiniCssExtractPlugin({
filename: 'style.min.css',
chunkFilename: "[name].css"
})
],
output: {
filename: 'app-compiled.min.js',
path: path.resolve(__dirname, 'js/assets')
},
optimization: {
splitChunks: {
chunks: 'all'
}
},
module: {
rules: [
{
test: /\.(scss)$/,
use: [
MiniCssExtractPlugin.loader,
'url-loader',
'css-loader',
'sass-loader'
]
},
]
}
};
我的最终目标是将 css 和 js 放在单独的文件中。我认为optimization 应该解决这个问题,但事实并非如此。从其他形式来看,MiniCssExtractPlugin 插件需要在css-loader 之前,但如果我这样做,我会从 SCSS 文件中得到一堆未解决的字体和 img 错误。使用 Mini 后,它无法编译,我得到一个...
const resource = this._identifier.split('!').pop();
^
TypeError: Cannot read property 'split' of undefined
没有它,文件会被监视,但不会在任何地方编译。我只需要 SASS 来编译。救命!!!
【问题讨论】: