描述
在 webpack 我使用mini-css-extract-plugin:
plugins: [
new MiniCssExtractPlugin({
filename: '[name].[hash].css',
chunkFilename: '[name].[hash].css',
})
]
在块文件中加载 scss 文件:
{
test: /\.scss$/,
use: [
{ loader: MiniCssExtractPlugin.loader, options: {
hmr: isdev,
reloadAll: true
}
},
"css-loader",
"sass-loader",
]
}
当我使用动态导入加载 scss 时:
import(/* webpackChunkName: "test" */ 'test.scss')
它将生成一个包含样式的test.[hash].css和一个test.[hash].js:
(window["webpackJsonp"] = window["webpackJsonp"] || []).push([[15],{
/***/ 81:
/***/ (function(module, exports, __webpack_require__) {
// extracted by mini-css-extract-plugin
/***/ })
}]);
问题
我想尽量减少延迟和加载文件,所以我发现有一个几乎空的test.[hash].js文件是多余的。
您是否有办法在 js 文件中包含 scss(参见想法 1)或不发出/使用几乎为空的 js 文件?
想法 1:不使用 mini-css-extract-plugin
我的第一个想法是不使用 mini-css-extract-plugin 来动态导入 scss,但这将在 js 中包含很多基于 css 的东西(https://github.com/webpack-contrib/extract-text-webpack-插件/问题/255)。