vue3+vite中使用自定义element-plus主题配置

自定义主题分为两种,一种是 全部导入 另一种是 按需导入 方式

全部导入方式

ps:默认已经安装跟在main.js中配置完毕

新建一个文件存放主题样式element.scss(路径为assets/scss/element.scss)

js 复制代码
// element.scss
@forward 'element-plus/theme-chalk/src/common/var.scss' with ( 
    $colors: ( 
        "primary": (
            "base": #7bb1f5,
        ),
    ),
);
// 这句记得要加
@use "element-plus/theme-chalk/src/index.scss" as *;

重点来了,需要在main.js中把引入的element-plus样式文件替换成自己写的

js 复制代码
// main.js
// 引入element-plus样式文件-------使用了自定义的主题样式这里就不能引入element-plus的样式文件否则不生效
// import 'element-plus/dist/index.css'  
import '@/assets/scss/element.scss'  

全部导入方式就搞定了。

按需导入方式

还是上面的那个element.scss文件

js 复制代码
// element.scss
@forward 'element-plus/theme-chalk/src/common/var.scss' with ( 
    $colors: ( 
        "primary": (
            "base": #7bb1f5,
        ),
    ),
);
// 这句要注释掉
// @use "element-plus/theme-chalk/src/index.scss" as *;

重点!!!!需要安装一个包 yarn add unplugin-element-plus --dev

js 复制代码
// vite.config.js
import { defineConfig } from 'vite'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
// 导入对应包 
import ElementPlus from 'unplugin-element-plus/vite'

export default defineConfig({
  // ...
  plugins: [
    // ...
    AutoImport({
      resolvers: [ElementPlusResolver({ importStyle: "sass" })], //这里记得需要添加一个配置
    }),
    Components({
      resolvers: [ElementPlusResolver({ importStyle: "sass" })], //这里记得需要添加一个配置
    }),
    // 按需定制主题配置
    ElementPlus({
        useSource: true,
    }),
  ],
  css: {
    preprocessorOptions: {
        scss: {
            additionalData: `
                @use "@/assets/scss/element.scss" as *;
                `,
            },
        },
    }
})

还有最后一点就是在main.js中把element-plus样式文件引入去掉

js 复制代码
// main.js
// 引入element-plus样式文件-------使用了自定义的主题样式这里就不能引入element-plus的样式文件否则不生效
// import 'element-plus/dist/index.css' 

ok了,这就是按需导入的方式。

相关推荐
toooooop85 分钟前
本地开发环境webScoket调试,保存html即用
前端·css·websocket
山有木兮木有枝_11 分钟前
手动封装移动端下拉刷新组件的设计与实现
前端
阳光阴郁大boy13 分钟前
大学信息查询平台:一个现代化的React教育项目
前端·react.js·前端框架
小菜全19 分钟前
uniapp新增页面及跳转配置方法
开发语言·前端·javascript·vue.js·前端框架
AlexMercer101222 分钟前
[前端]1.html基础
前端·笔记·学习·html
白水清风31 分钟前
关于Js和Ts中类(class)的知识
前端·javascript·面试
小菜全41 分钟前
uniapp基础组件概述
前端·css·vue.js·elementui·css3
小天呐1 小时前
qiankun 微前端接入实战
前端·js·微前端
周航宇JoeZhou1 小时前
JP4-7-MyLesson后台前端(五)
java·前端·vue·elementplus·前端项目·mylesson·管理平台
Yaavi1 小时前
一个基于markdown的高性能博客模板
前端·开源·源码