实现效果:

根据选择的皮肤,自动切换对应的element ui主题

实现思路:

1.使用element ui自带的主题编辑器设置需要的配色方案并下载主题
2.通过gulp为主题的所有css文件扩展命名空间
3.切换选项动态为body添加class

具体实现

一、设置配色得到自定义主题

使用element ui自带的主题编辑器设置需要的配色方案并下载主题

官网:https://element.eleme.cn/#/zh-CN/theme

element 主题 在线 elementui主题定制_gulp


设置好之后下载,解压后得到theme文件夹(包含字体文件及样式文件index.css)

官网的另一种方式

element 主题 在线 elementui主题定制_css_02


我用这种方式的时候执行et报错primordials is not defined

百度了一下大部分方法是回退node版本,当时我不想回退,后来发现了另一个解决办法,在这里记录下:

npm i element-themex -g 解决element ui 自定义主题失败(primordials is not defined)问题

二、通过gulp为主题的所有css文件扩展命名空间

2.1安装gulp
1.安装gulp://这一步最好在cmd下全局安装,我一开始在项目下执行了到用的时候提示未安装
npm install gulp
2.安装gulp-clean-css
npm install gulp-clean-css
3.安装gulp-css-wrap
npm install gulp-css-wrap

在项目根目录创建gulpfile.js

// gulpfile.js
var path = require('path')
var gulp = require('gulp')
var cleanCSS = require('gulp-clean-css')
var cssWrap = require('gulp-css-wrap')
gulp.task('css-wrap', function () {
    return gulp.src(path.resolve('./theme/index.css'))
    /* 找需要添加类名的css文件,支持正则表达式 */
        .pipe(cssWrap({
            selector: '.blue' /* 添加的类名 */
        }))
        .pipe(cleanCSS())
        .pipe(gulp.dest('src/assets/css/theme/blue')) /* 存放的目录 */
})
2.2为主题的所有css文件扩展命名空间

把第一步解压好的theme文件放到项目根目录(不是根目录也行,只需要保证gulpfile.js中路径写对就行)

gulpfile.js中可以设置文件路径及存储路径

执行gulp css-wrap

element 主题 在线 elementui主题定制_elementui_03


执行成功后就能在你设置的存储路径那找到对应的css文件了,把解压后的theme文件夹中的字体文件夹也放过去就完成啦

element 主题 在线 elementui主题定制_element 主题 在线_04

三、切换选项动态为body添加class

3.1在main.js中引入需切换的样式文件

import './assets/css/theme/blue/index.css' import './assets/css/theme/green/index.css'

3.2切换事件

引入change-theme.js,切换时调用Themefuc 方法

change-theme.js

export const Themefuc = (themeName) => {
    window.sessionStorage.setItem('theme',themeName) //储存当前主题名
    document.body.className = themeName;//动态为body添加class
}
3.3刷新默认加载选择的主题

main.js中

// 页面刷新时,重新赋值
let theme = window.sessionStorage.getItem('theme');
store.dispatch('app/setTheme', theme?theme:'blue')//首次加载默认blue主题

app.js中

const actions = {
    // 更改主题
    setTheme({ commit }, theme) {
        commit('SET_THEME', theme);
        console.log('theme' + theme);
        Themefuc(document.body, theme);
        sessionStorage.setItem('theme', theme);
    }
};
export default {
    actions
};

ps.
这种方式是将用到的几种样式都提前加载,不太适合需切换的样式太多的情况