当前位置:   article > 正文

webpack-theme-color-replacer自定义element-ui主题

webpack-theme-color-replacer

前言

因为项目采用UI组件element-ui,需要部署后(打包后)设置主题,在网上找了一遍,如下几种方法。

1/使用全局样式覆盖(工作量大)

2/自定义element-ui配色,element-ui提供了一个配置页面 和 配色工具,可以本地生成固定的几套主题色,以便来实现主题切换(编译后无法修改)

3/ 通过后端返回css文件,前端配合使用localStorage,储存主题对应的参数,后端返回对应的css主题文件(和方法2一样,需要先生成多个主题css文件)

4/通过改变element-ui的样式变量(无法将变量通过js传入)
        

  1. $--color-primary: #409EFF; // 主题色
  2. $--color-success: #52C41A; // 成功颜色
  3. $--color-warning: #FAAD14; // 警告颜色
  4. $--color-danger: #F5222D; // 错误危险颜色
  5. $--color-info: #999999; // 信息颜色

 上面的方案都无法满足编译后修改element-ui主题,最终找到webpack-theme-color-replacer解决。

步骤一

        安装 webpack-theme-color-replacer
        npm install ---save webpack-theme-color-replacer

步骤二

        vue.config.js引入插件
        

  1. const ThemeColorReplacer = require('webpack-theme-color-replacer')
  2. const forElementUI = require('webpack-theme-color-replacer/forElementUI')

  1. chainWebpack: config => {
  2. // 自定义换肤
  3. config.plugin('webpack-theme-color-replacer')
  4. .use(ThemeColorReplacer)
  5. .tap(options => {
  6. const matchColors = []
  7. const data = ['#409EFF', '#52C41A', '#FAAD14', '#F5222D', '#999999']
  8. data.forEach(item => {
  9. matchColors.push(...forElementUI.getElementUISeries(item))
  10. })
  11. options[0] = {
  12. fileName: 'css/theme-colors-[contenthash:8].css',
  13. matchColors: matchColors,
  14. changeSelector: forElementUI.changeSelector,
  15. isJsUgly: process.env.NODE_ENV !== 'development'
  16. }
  17. return options
  18. })
  19. }

我这边是修改了5种element-ui按钮类型的样式

步骤三 
        

新建themColorClient.js文件来切换主题,代码如下

  1. import client from 'webpack-theme-color-replacer/client'
  2. import forElementUI from 'webpack-theme-color-replacer/forElementUI'
  3. export const curColor = window.g.ThemeColor
  4. // 动态切换主题色
  5. export function changeThemeColor () {
  6. const data = []
  7. Object.values(curColor).forEach(item => {
  8. data.push(...forElementUI.getElementUISeries(rgbToHex(item)))
  9. })
  10. const options = {
  11. newColors: data,
  12. changeUrl (cssUrl) {
  13. console.log('cssUrl', cssUrl)
  14. return `${window.g.VUE_DYD_CONFIG_URL}/${cssUrl}`
  15. }
  16. }
  17. return client.changer.changeColor(options, Promise)
  18. }
  19. export function rgbToHex (rgb) {
  20. if (rgb.indexOf('rgb') > -1) {
  21. // rgb(x, y, z)
  22. const color = rgb.replace(/(?:\(|\)|rgba|RGBA)*/g, '').split(',') // 把 x,y,z 推送到 color 数组里
  23. let hex = '#'
  24. for (let i = 0; i < 3; i++) {
  25. // 'Number.toString(16)' 是JS默认能实现转换成16进制数的方法.
  26. // 'color[i]' 是数组,要转换成字符串.
  27. // 如果结果是一位数,就在前面补零。例如: A变成0A
  28. hex += ('0' + Number(color[i]).toString(16)).slice(-2)
  29. }
  30. return hex
  31. } else {
  32. return rgb
  33. }
  34. }

changeThemeColor 设置主题颜色

rgbToHex rgba转hex 因为项目中之前配置的颜色有rgba的所以这边需要转译下 forElementUI.getElementUISeries 只支持 hex 

为了便于用户配置对应的主题色,我这边设置的是对象,对应element-ui的五个按钮色调

步骤四 

调用 changeThemeColor方

在main.js里初始化调用initThemeColor

 注意事项

如果运行提示生成的css文件未找到,一般都是由于vue.config.js里的这块设置的颜色没有对应的主题色

 之前参考网上的文章无法做到一对一的改变,是因为没有一一对应,需使用forElementUI.getElementUISeries方法实现对应

 项目中用到webpack ModuleFederationPlugin实现分包,多项目编译时,导致其中一个项目中主题css文件找不到,需要在themColorClient.js中配置如下

window.g.VUE_DYD_CONFIG_URL为另外一个项目的访问地址,如当前项目本地服务为localhost:8081,另一个项目为localhost:8082,则这块配置为localhost:8082,这块个人觉得跟ModuleFederationPlugin remotes有关,有了解朋友欢迎一起讨论

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/638104
推荐阅读
相关标签
  

闽ICP备14008679号