Skip to content

Latest commit

 

History

History
117 lines (95 loc) · 4.62 KB

README_zh.md

File metadata and controls

117 lines (95 loc) · 4.62 KB

webpack 多主题编译

Build Status Coverage Status Packagist webpack

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

API

调用说明

/**
 * @param configs - 插件配置
 */
multipleThemesCompile(configs);

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)
 })