自定义elementui主题

1、在线主题编辑器

官方提供的在线主题编辑器,可以直观的查看修改后的效果,编辑好下载,然后再引入到项目中。

主题定制

// /assets/styles/index.less
// @import "~element-plus/lib/theme-chalk/index.css";
@import 'theme/index.css';

// main.js
import '@/assets/styles/index.less';

2、命令行主题工具

使用nodejs高版本安装该工具后期执行时会报错primordials is not defined,如下图所示。

报错截图

建议先安装node版本管理工具,再来安装命令行主题工具。

2.1 win10安装nodejs版本管理工具

nvm全名node.js version management,是一个nodejs的版本管理工具。通过它可以安装和切换不同版本的nodejs。

nvm应用程序

下载款选安装包后,解压安装成功后,可进行如下操作:

  • 查看本地安装的所有nodejs版本:nvm list
  • 安装指定nodejs版本:nvm install 10.0.0
  • 使用指定nodejs版本:nvm use 10.0.0
  • 卸载指定nodejs版本:nvm unintstall 12.0.0
  • 开启nodejs版本切换:nvm on
  • 关闭nodejs版本切换:nvm off
    通过node -v查看当前nodejs版本。

2.2 自定义主题

为了使用element-theme主题工具,建议nodejs的版本设置为10.0.0。操作步骤如下:

  1. 安装主题生成工具:npm i element-theme -g
  2. 创建临时目录:mkdir element-theme
  3. cd element-theme
  4. 安装白垩主题:npm i element-theme-chalk -D
  5. 初始化变量文件:et -i
  6. 根据自己需要,修改element-variables.scss 文件
  7. 编译主题:et
    编译成功后,会在该目录下生成theme文件夹,引入到项目中就行。
// /assets/styles/index.less
// @import "~element-plus/lib/theme-chalk/index.css";
@import 'theme/index.css';

// main.js
import '@/assets/styles/index.less';

3、修改SCSS变量

elementui样式使用scss来编写的,可以通过修改scss变量来达到改变主题的效果。新建一个样式文件,例如: element-style.scss

3.1 vue2(elementui)

/* 改变主题色变量 */
$--color-primary: teal;

/* 改变 icon 字体路径变量,必需 */
$--font-path: '~element-ui/lib/theme-chalk/fonts';

@import "~element-ui/packages/theme-chalk/src/index";

3.2 vue3(elementplus)

@forward "element-plus/theme-chalk/src/common/var.scss" with (
  $colors: (
    'white': #161616,
    'black': #161616,
    'primary': (
      'base': #F85A1F,
    ),
    'success': (
      'base': #139705,
    ),
    'warning': (
      'base': #F85A1F,
    ),
    'danger': (
      'base': #B51212,
    ),
    'error': (
      'base': #B51212,
    ),
    'info': (
      'base': #161616,
    )
  ),
  $background-color-base: #161616 !default,
  $border-color-hover: #F85A1F !default,
  $border-color: (
    'base': #161616,
    'light': #D1D1D1,
    'lighter': #FBFBFB,
    'extra-light': #f2f6fc,
  ),
  $text-color: (
    'primary': #FBFBFB,
    'regular': #FFE8D1,
    'secondary': #D1D1D1,
    'placeholder': #8F8F8F,
  ),
  $border-radius: (
    'base': 20px,
    'small': 20px,
    'round': 20px,
    'circle': 100%,
  )
);
// 如果你想导入所有样式,如下。 如果只是按需导入,则可以忽略以下内容。
@use "element-plus/theme-chalk/src/index.scss" as *;

最后,在项目的入口文件中,直接引入以上样式文件即可:

import './element-style.scss'
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,366评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,521评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,689评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,925评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,942评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,727评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,447评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,349评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,820评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,990评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,127评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,812评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,471评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,017评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,142评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,388评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,066评论 2 355

推荐阅读更多精彩内容