elementPlus自定义主题

场景

elementPlus默认的颜色是
#409eff 下面这种蓝色
在这里插入图片描述
但项目要求的是
#06b0b2下面这种颜色
在这里插入图片描述

解决方案有以下几种

1、通过 CSS 变量设置

  • 可以实现但不推荐
    CSS 变量是一个非常有用的功能,几乎所有浏览器都支持。 (IE:啊这?)
    element用 css 变量来重构了几乎所有组件的样式系统。

它兼容 SCSS 变量系统。 使用 SCSS 的函数自动生成需要用到的 css 变量。

所以可以动态地改变组件内的个别变量,以便更好地自定义组件样式,而不需要修改 SCSS 文件重新编译一次。

可以利用这一点直接在App.vue

1.1 css 实现
:root {
  --el-color-primary: #06b0b2;
  ...
}

需要注意的是 element官方并不推荐直接写到全局的 :root这种做法会存在一些性能问题。
那么我们可以

#app {
  --el-color-primary: #06b0b2;
  ...
}
1.2 js实现

也可以通过 js 控制 css 变量

// document.documentElement 是全局变量时
const el = document.documentElement
// const el = document.getElementById('xxx')

// 获取 css 变量
getComputedStyle(el).getPropertyValue(`--el-color-primary`)

// 设置 css 变量
el.style.setProperty('--el-color-primary', '#06b0b2')

在这里插入图片描述
可以观察到 对于颜色的css变量,element有个逐渐变浅的处理,但是如果我们使用css变量去设置主题的话那就意味着我们对于这些也是需要一层一层去设置的。
效果可以做到但是会产生很多不必要的代码

2、通过 SCSS 变量

$colors: () !default;
$colors: map.deep-merge(
  (
    'white': #ffffff,
    'black': #000000,
    'primary': (
      'base': #409eff,
    ),
    'success': (
      'base': #67c23a,
    ),
    'warning': (
      'base': #e6a23c,
    ),
    'danger': (
      'base': #f56c6c,
    ),
    'error': (
      'base': #f56c6c,
    ),
    'info': (
      'base': #909399,
    ),
  ),
  $colors
);

3、覆盖

  • 首先新建一个样式文件,例如 styles/element/index.scss
// styles/element/index.scss
/* 只需要重写你需要的即可 */
$--color-primary: #06B0B2;
@forward 'element-plus/theme-chalk/src/common/var.scss' with (
  $colors: (
    'primary': (
      'base': $--color-primary,
    ),
  ),
);

// 如果只是按需导入,则可以忽略以下内容。
// 如果你想导入所有样式:
// @use "element-plus/theme-chalk/src/index.scss" as *;
  • 然后在项目入口文件中,导入这个样式文件以替换 Element Plus 内置的 CSS

项目是webpack时:

//vue.config.js / vue.config.ts
//关于plugin的就是看自己项目就好
  css: {
    loaderOptions: {
      scss: {
        additionalData: `@use "~/styles/element/index.scss" as *;`,
      },
    },
  },

项目是vite时:
使用 scss.additionalData 来编译所有应用 scss 变量的组件。

import path from 'path'
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
// 你也可以使用 unplugin-vue-components
// import Components from 'unplugin-vue-components/vite'
// import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'

// 或者使用 unplugin-element-plus
import ElementPlus from 'unplugin-element-plus/vite'

// vite.config.ts
export default defineConfig({
  resolve: {
    alias: {
      '~/': `${path.resolve(__dirname, 'src')}/`,
    },
  },
  //比较关键的依旧是这段
  css: {
    preprocessorOptions: {
      scss: {
        additionalData: `@use "~/styles/element/index.scss" as *;`,
      },
    },
  },
  
  plugins: [
    vue(),
    // use unplugin-vue-components
    // Components({
    //   resolvers: [
    //     ElementPlusResolver({
    //       importStyle: "sass",
    //       // directives: true,
    //       // version: "2.1.5",
    //     }),
    //   ],
    // }),
    // 或者使用 unplugin-element-plus
    ElementPlus({
      useSource: true,
    }),
  ],
})

之所以用@use 'xxx.scss' as *而不是 @import 'xxx.scss'
是因为 sass 团队说他们最终会删除 @import 语法。
Sass: @use
Sass: @import

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
Element Plus提供了一键换肤的功能,可以通过自定义主题色来改变项目的外观。在Vue3中使用Element Plus进行换肤的过程可以通过修改代码文件来实现。 首先,在layout/index.vue文件中,可以看到通过监听主题的变化来加载对应的主题样式。通过设置document.documentElement的style属性和body元素的class属性来改变页面的主题样式。 其次,在layout/header.vue文件中,可以看到通过el-dropdown和el-dropdown-menu实现了一个下拉菜单,用于选择不同的主题。每个主题都对应着一个颜色和一个标签,在点击菜单项时可以触发handleCommandTheme方法来切换主题。 通过修改这些代码文件中的相关部分,你可以自定义Element Plus的主题色,并实现一键换肤的效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue3+element-plus自定义主题色,一键换肤](https://blog.csdn.net/wuufeii/article/details/120038295)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [vue3 + element-plus 实现一键换肤](https://blog.csdn.net/maoeye283301717/article/details/128149978)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

伊昂呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值