English | 中文版
这个库用于复写 webpack 配置以达到输出多套 css 的目的。
如果你使用的是 Webpack3 及以下版本,请使用[email protected]
如果你使用的是 Webpack4 的版本,请使用[email protected]
npm i webpack-multiple-themes-compile webpack-merge
原始webpack.config.js
module.exports = {
output: {
path: outPutPath,
filename: '[name].js',
chunkFilename: '[name].js',
},
// 这里是其他的options
};
修改 webpack.config.js
+ const merge = require('webpack-merge');
+ const multipleThemesCompile = require('webpack-multiple-themes-compile');
- module.exports = {
+ const webpackConfigs = {
output: {
path: outPutPath,
filename: '[name].js',
chunkFilename: '[name].js'
}
// 这里是其他的options
};
+ module.exports = merge(
+ webpackConfigs,
+ multipleThemesCompile({
+ themesConfig: {
+ green: {
+ color: '#008000'
+ },
+ yellow: {
+ import: [
+ '~thirdpartylibrary/styles/yellow.less'
+ ],
+ color: '#ffff00'
+ }
+ },
+ lessContent: 'body{color:@color}'
+ })
+ );
输出
.
├── theme-green.css
├── theme-yellow.css
└── themes.js
调用说明
/**
* @param configs - 插件配置
*/
multipleThemesCompile(configs);
属性名称 | 类型(默认值) |
描述 |
---|---|---|
styleLoaders | Array [{ loader: 'css-loader' }, { loader: 'less-loader' }] |
处理 less 文件的 loader。详见 webpack 官访文档 |
themesConfig* | Object | 主题配置 , key 为生成的 css 的文件名,value 为一个对象。该对象的 key、value 分别为需要覆盖的变量名、变量值 |
lessContent | String | (themeName:string,config:Object)=> String @import "../index"; |
缓存的 less 文件的内容 |
preHeader | String // Generate by Script. |
生成文件的文件头内容 |
cacheDir | String ./src/less/themes |
缓存文件的目录 |
cwd | String __dirname |
相对输出路径 |
outputName | String theme-[name].css |
最终输出的文件名。这个配置和 webpackOptions.output 一致。 |
publicPath | String../../ |
mini-css-extract-plugin 的publicPath配置 |
如果使用了 html-webpack-plugin
则可能需要增加以下配置
new HtmlwebpackPlugin({
filename: 'index.html',
template: 'src/index.html',
inject: 'body',
// 排除 themes.js
+ excludeChunks: Object.keys(themesConfig)
})