vue3按需引入element-plus并修改主题颜色

1、安装element-plus

# NPM
$ npm install element-plus --save

2、element-plus按需引入

快速开始 | Element Plus (element-plus.org)

需要安装unplugin-vue-components 和 unplugin-auto-import这两款插件。

npm install -D unplugin-vue-components unplugin-auto-import

vite配置文件添加以下代码:

// 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'

export default defineConfig({
  // ...
  plugins: [
    // ...
    AutoImport({
      resolvers: [ElementPlusResolver()],
    }),
    Components({
      resolvers: [ElementPlusResolver()],
    }),
  ],
})

完成按需引入。

3、element-plus图标引入

Icon 图标 | Element Plus (element-plus.org)

为了能够像官方文档的用例那样直接使用图标,需要全局注册组件。

安装 :

# NPM
npm install @element-plus/icons-vue

全局注册 :

// main.js

// 如果您正在使用CDN引入,请删除下面一行。
import * as ElementPlusIconsVue from '@element-plus/icons-vue'

const app = createApp(App)
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
  app.component(key, component)
}

完成图标的全局注册,可以直接使用了。

若遇到全局注册的图标不生效的地方,可以直接引入图标使用:

<script setup>
import { Search } from '@element-plus/icons-vue'

</script>

<template>
  <div class="login">
                <el-form-item prop="username">
                  <el-input
                    v-model="loginForm.username"
                    placeholder="用户名"
                    :prefix-icon="Search"
                  />
                </el-form-item>
                <el-form-item prop="password">
                  <el-input
                    v-model="loginForm.password"
                    placeholder="密码"
                    :prefix-icon="Search"
                  />
                </el-form-item>
  </div>
</template>

4、修改主题颜色

主题 | Element Plus (element-plus.org)

新建文件styles/element/index.scss,修改element主题色&全局预定义scss变量就在这个文件。

// styles/element/index.scss
/* 只需要重写你需要的即可 */
@forward 'element-plus/theme-chalk/src/common/var.scss' with (
  $colors: (
    'primary': (
      'base': green,
    ),
  ),
);

// 如果只是按需导入,则可以忽略以下内容。
// 如果你想导入所有样式:
// @use "element-plus/theme-chalk/src/index.scss" as *;

vite配置文件添加以下代码:

import { fileURLToPath, URL } from 'node:url'
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'


// vite.config.js
export default defineConfig({
  plugins: [
    vue(),
    AutoImport({
      resolvers: [ElementPlusResolver({
        // 注意
        importStyle: 'sass'
      })]
    }),
    Components({
      resolvers: [ElementPlusResolver({
        // 注意
        importStyle: 'sass'
      })]
    }),
  ],
  resolve: {
    alias: {
      '@': fileURLToPath(new URL('./src', import.meta.url))
    }
  },
  css: {
    preprocessorOptions: {
      scss: {
        // 修改element主题色 & 全局预定义scss变量 在这个文件
        additionalData: `@use "@/styles/element/index.scss" as *;`,
      },
    },
  },
})

完成主题颜色修改,需要注意按需导入的地方配置importStyle: 'sass',修改主题否则无效。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值