vue3+vite 项目中怎么引入 elementplus 组件库

一:完整引入

  • 安装:npm i element-plus --save
  • 步骤:main.js 中添加以下内容
js 复制代码
import { createApp } from 'vue'
import App from './App.vue'

import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'

const app = createApp(App)
app.use(ElementPlus)
app.mount('#app')

二:按需引入

  • 安装:npm i element-plus --save
  • 安装插件:npm install -D unplugin-vue-components unplugin-auto-import
  1. vite.config.ts 中添加配置
ts 复制代码
// vite.config.ts
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: [
      	vue(),
    	// 按需引入组件的样式
        AutoImport({
            resolvers: [ElementPlusResolver()],
        }),
        Components({
            resolvers: [ElementPlusResolver()],
        }),
    ],
})
  1. src / plugins / element-plus.ts 配置按需引入组件
js 复制代码
import { ElButton, ElDialog } from "element-plus";
// 引入类型,加上 type
import type { App } from "vue"

const setupElementPlus = (app: App) => {
    app.use(ElButton)
    app.use(ElDialog)
}

export default setupElementPlus
  1. main.ts 导入该配置
js 复制代码
import setupElementPlus from './plugins/element-plus'
const app = createApp(App)
// 传入 app
setupElementPlus(app)
  1. App.vue 测试
js 复制代码
<el-button type="primary" :icon="Plus" @click="test">经典按钮</el-button>
<script lang="ts" setup>
import { Plus } from "@element-plus/icons-vue";
import { ElMessage } from "element-plus";
// 如果只是用组件 API,您需要手动导入样式
import "element-plus/es/components/message/style/css";

const test = () => {
    ElMessage.success("登陆成功");
};
</script>
相关推荐
界面开发小八哥5 分钟前
界面控件Kendo UI for Angular 2025 Q2新版亮点 - 增强跨设备的无缝体验
前端·ui·界面控件·kendo ui·angular.js
midsummer_woo20 分钟前
基于springboot+vue+mysql的中药实验管理系统设计与实现(源码+论文+开题报告)
vue.js·spring boot·mysql
枷锁—sha1 小时前
从零掌握XML与DTD实体:原理、XXE漏洞攻防
xml·前端·网络·chrome·web安全·网络安全
F2E_Zhangmo1 小时前
基于cornerstone3D的dicom影像浏览器 第二章,初始化页面结构
前端·javascript·vue·cornerstone3d·cornerstonejs
代码的余温1 小时前
如何区别HTML和HTML5?
前端·html·html5
天下无贼!1 小时前
【样式效果】纯CSS从零到一实现动态彩色背景效果
前端·css
DoraBigHead1 小时前
手写 `new`、`call`、`apply`、`bind` + V8 函数调用机制解密
前端·javascript·面试
_pengliang1 小时前
css 音频波浪动画-小程序\PC可用
前端·css·小程序
ai小鬼头2 小时前
AIStarter教你快速打包GPT-SoVITS-v2,解锁AI应用市场新玩法
前端·后端·github
JQLvopkk2 小时前
C#通过HslCommunication连接西门子PLC1200,并防止数据跳动的通用方法
前端·javascript·算法