仲灏小栈 仲灏小栈
首页
大前端
后端&运维
其他技术
生活
关于我
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

仲灏

诚意, 正心, 格物, 致知
首页
大前端
后端&运维
其他技术
生活
关于我
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 《前端项目基础建设》
  • HTML&CSS

  • JavaScript&TypeScript

  • Node

  • 构建

  • Vue

    • 持久化存储实时读取
    • vue自适应布局
    • Vue 中后台表格的增删改查统一解决方案(mixin版)
    • Vue 中后台表格的增删改查同一解决方案(组件封装版)
    • Vue Render自定义table单元格内容
    • 项目初始化编码规范(eslint,prettier等)
    • vue element-ui 换肤功能开发
    • vue element 定义多种主题实现换肤
      • 结果图
      • 安装依赖
        • 配置element-theme
        • 配置gulp
    • 大屏自适应容器
    • el-upload 自定义上传进度
    • vue3初学注意点
    • vue3 hooks 自适应可视化大屏
    • vue3 element-plus ant- design 自定义主题
    • 博客开发
    • vue2中使用jsx
    • Vue 放弃繁琐的render函数,拥抱JSX
    • 组件设计步骤
    • 倒计时验证
    • Vue中computed和watch的区别
    • vue3面试聚焦
    • Vue3 原理 Proxy实现响应式
  • React

  • 小程序

  • 跨端

  • Electron

  • WebGL&GIS

  • 浏览器

  • 面经

  • 其他

  • 大前端
  • Vue
仲灏
2022-01-13
目录

vue element 定义多种主题实现换肤

# 结果图

image-20220113173450084

image-20220113173558775

# 安装依赖

package.json

{
  ...
  "dependencies": {
    ...
    "element-ui": "^2.13.2",
    ...
  },
  "devDependencies": {
    ...
    "element-theme": "^2.0.1",
  	"element-theme-chalk": "^2.13.2",
    "gulp-autoprefixer": "^7.0.1",
    "gulp-clean-css": "^4.3.0",
    "gulp-load-plugins": "^2.0.3",
    "gulp-rename": "^2.0.0",
    "gulp-sass": "^4.1.0",
    ...
  },
  ...
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

gulp3 需要搭配 node10使用

# 配置element-theme

/package.json

{
  ...
  "element-theme": {
    "config": "./src/element-ui/theme-variables.scss",
    "out": "./src/element-ui/theme",
    "minimize": true,
    "browsers": [
      "> 1%",
      "last 2 versions",
      "not ie <= 10"
    ]
  },
  ...
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14

# 配置gulp

/gulpfile.js

var gulp = require('gulp')
var $ = require('gulp-load-plugins')()
var fs = require('fs')
var path = require('path')
var del = require('del')
//var colors = require('colors')
var child_process = require('child_process')

var theme = {}
var themeList = require('./src/element-ui/config.js').filter(item => !item.hasBuild)
var styleFileDir = './src/assets/scss'
var styleFileDirTemp = `${styleFileDir}-temp`
var themeFileDir = './public/element-theme'
var et = require('element-theme')
var etOptions = require('./package.json')['element-theme']
var themeFileName = etOptions.config.replace(/.*\/(.+\.scss)/, '$1')

/**
 * 构建生成主题
 */
gulp.task('themes', () => {
  if (themeList.length <= 0) {
    return del(styleFileDirTemp)
  }

  // 删除临时文件,保证本次操作正常执行
  //del(styleFileDirTemp)
  console.log('del(styleFileDirTemp)')

  // 拷贝一份scss样式文件夹,作为构建的临时处理文件夹
  //child_process.spawnSync('cp', ['-r', styleFileDir, styleFileDirTemp])
  console.log('copy styleFileDirTemp')

  // 拷贝element组件scss变量样式文件至临时处理文件夹中,并修改相应配置信息
  //child_process.spawnSync('cp', ['-r', etOptions.config, styleFileDirTemp])
  etOptions.config = `${styleFileDirTemp}/${themeFileName}`

  // 开始构建生成
  fnCreate(themeList)

  function fnCreate(themeList) {
    if (themeList.length >= 1) {
      // 保存当前构建生成的主题对象
      theme = themeList[0]

      console.log('\n')
      console.log('-------------------- 待构建,主题 -------------------------')
      console.log(themeList)
      console.log('\n')
      console.log('-------------------- 构建中,主题 -------------------------')
      console.log(theme)
      console.log('\n')

      // 修改.scss临时文件中的$--color-primary主题变量值
      var data = fs.readFileSync(etOptions.config, 'utf8')
      var result = data.replace(
        /\$--color-primary:(.*) !default;/,
        `$--color-primary:${theme.color} !default;`
      )
      fs.writeFileSync(path.resolve(etOptions.config), result)

      // 修改aui.scss临时文件中引入element组件主题变量文件路径
      var data = fs.readFileSync(`${styleFileDirTemp}/aui.scss`, 'utf8')
      var result = data.replace(new RegExp(`(@import \")(.*\/)(${themeFileName}\";)`), '$1./$3')
      fs.writeFileSync(path.resolve(`${styleFileDirTemp}/aui.scss`), result)

      // 调用element-theme插件,生成element组件主题
      etOptions.out = `${themeFileDir}/${theme.name}`
      et.run(etOptions, () => {
        // 生成后,构建同主题色aui.css项目主题
        gulp.start(['styles'], () => {
          // 递归下一步
          themeList.splice(0, 1)
          fnCreate(themeList)
        })
      })
    } else {
      // 删除临时文件
      del(styleFileDirTemp)
      console.log('\n')
      console.log('-------------------- 构建完毕,删除临时文件 -------------------------')
      console.log(styleFileDirTemp)
      console.log('\n')

      // 删除主题不需要的部分文件
      var files = [
        `${themeFileDir}/**/*.css`,
        `!${themeFileDir}/**/index.css`,
        `!${themeFileDir}/**/aui.css`,
        `!${themeFileDir}/**/fonts`
      ]
      del(files)
      console.log('-------------------- 构建完毕,删除主题独立组件文件 -------------------------')
      console.log(files)
      console.log('\n')
    }
  }
})

gulp.task('styles', () => {
  return gulp
    .src([`${styleFileDirTemp}/aui.scss`])
    .pipe($.sass().on('error', $.sass.logError))
    .pipe(
      $.autoprefixer({
        browsers: etOptions.browsers,
        cascade: false
      })
    )
    .pipe($.cleanCss())
    .pipe($.rename('aui.css'))
    .pipe(gulp.dest(`${themeFileDir}/${theme.name}`))
})

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
上次更新: 2022/06/05, 20:31:36
vue element-ui 换肤功能开发
大屏自适应容器

← vue element-ui 换肤功能开发 大屏自适应容器→

最近更新
01
vim日常使用记录
04-02
02
滑动窗口最大值
04-02
03
有效的字母异位词
04-02
更多文章>
Theme by Vdoing | Copyright © 2021-2025 izhaong | github | 蜀ICP备2021031194号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式