我想让我的应用程序使用 2 个单独的 css 文件(同时),这些文件是从不同的文件生成的(1 个来自scss
文件,一个来自less
文件);两个文件名都应该被散列。
我目前已将 webpack 配置为生成 2 个 css 文件;但是,在开发模式下,电极不消耗第二个,而在生产模式下,电极不消耗第一个。生成的同构加载器文件列出了两者(在“主”块中)。
看起来输出index.html
是在electrode-react-webapp/lib/default-handlers.js:65-68中生成的,这会产生一个<link>
标签。所以我想我做错了。
我electrode-react-webapp: ^2.0.0
继续webpack: ^3.0.0
const extractLess = new ExtractTextPlugin({
allChunks: true,
disable: isDev,
filename: `semantic-ui${isDev ? '' : '.[hash]'}.css`,
});
const extractSass = new ExtractTextPlugin({
allChunks: true,
disable: isDev,
filename: `gemini${isBundling ? '[name]' : ''}${isDev ? '' : '.[hash]'}.css`,
});
const lessRule = {
test: /\.less$/,
use: extractLess.extract({
// …
})
};
const sassRule = {
test: /\.scss$/,
use: extractSass.extract({
// …
})
};
// …
composer.addPartials([ // webpack-config-composer
{
'app-style': {
config: {
module: { rules: [ sassRule ] },
},
},
},
{
'semantic-style': {
config: {
module: { rules: [ lessRule ] },
},
},
},
]);
// register custom styles
const { _base } = composer.profiles;
const _extractStyle = _base.partials['_extract-style'];
_base.partials['app-style'] = { order: _extractStyle.order };
_base.partials['semantic-style'] = { order: _extractStyle.order };
delete _base.partials['_extract-style']; // `.enable = false` doesn't work
const config = compose();