经过反复测试,实现的效果比较理想。而且还可以根据需要,替换掉任意数目的颜色。理论上是只要是css的颜色,都可以通过这个插件来提取颜色样式。

三、实施方法

  1. 下载依赖包,执行命令 npm i -D webpack-theme-color-replacer
  2. 修改配置文件webpack.base.conf.js,修改内容如下:
const forElementUI = require('webpack-theme-color-replacer/forElementUI')
const ThemeColorReplacer = require('webpack-theme-color-replacer')
module.exports = {
 .....
  plugins: [
      //生成仅包含颜色的替换样式(主题色等)
      new ThemeColorReplacer({
          fileName: 'css/theme-colors.[contenthash:8].css',
          matchColors: [
              ...forElementUI.getElementUISeries(appConfig.themeColor),  				                           //element-ui主色系列
              '#0cdd3a',  //自定义颜色
              '#c655dd',
          ],
          changeSelector: forElementUI.changeSelector,
          isJsUgly: config.isBuild,
          // resolveCss(resultCss) { // optional. Resolve result css code as you wish.
          // return resultCss + youCssCode
          // }
      })
  ],
   }
  1. 页面配置,配置内容如下:
<change-color></change-color>
     
<el-button @click="reset" size="small" style="float: right;">Reset</el-button>
import changeColor from './changeColor.vue'
   export default {
       props: {},
       data() {
           return {};
       },
       methods: {
           reset() {
               localStorage.removeItem('theme\_color')
               location.reload()
           }
       },
       computed: {},
       components: { changeColor, footCode }
   }

四、优化

提醒:若需要进行颜色替换的页面较多,可考虑将颜色替换组件设置为全局自定义组件。实现方式如下:

  1. main.js中全局注册到vue
import MyBread from '@/components/common/MyBread.vue'
Vue.component("MyBread", MyBread);//全局自定义组件
  1. 在需要的组件中可以直接使用,注意需要父子传值
<MyBread level1="用户管理" level2="用户列表"></MyBread>

注:在进行主体色变换时,若需要替换的主体色较多时,在初始化新的主体色数组时,应新增相应数量的色彩元素。否则,匹配的主体色不会生效。