element-plus中如何实现按需导入与全局导入
作者:哈哈与黑洞大笑 时间:2024-05-02 17:04:21
按需导入:
安装插件
首先需要引入额外的插件:前**vite-plugin-components
已重命名为unplugin-vue-components
**
npm install unplugin-vue-components
配置插件
在weapack或vite配置文件内中添加配置
// vite.config.ts
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
?
export default {
?plugins: [
? ?// ...
? ?Components({
? ? ?resolvers: [ElementPlusResolver()],
? }),
],
}
// webpack.config.js
const Components = require('unplugin-vue-components/webpack')
const { ElementPlusResolver } = require('unplugin-vue-components/resolvers')
?
module.exports = {
?// ...
?plugins: [
? ?Components({
? ? ?resolvers: [ElementPlusResolver()],
? }),
],
}
//main.ts
import { createApp } from 'vue'
import App from './App.vue'
?
import { Edit,Search } from '@element-plus/icons' ?//图标需要分开导入,按需导入图标
import { ElButton } from 'element-plus'; ? //按需导入
?
const app = createApp(App);
//注册组件
app.component("edit", Edit)
app.component("search", Search)
app.component('ElButton',ElButton)
app.mount('#app');
<template>
<h2>home页面</h2>
? ?<el-button type="primary" >主要按钮</el-button>
? ?<el-button type="success" >成功按钮</el-button>
? ?<el-icon :size="20" :color="'blue'">
? ? ? ?<edit />
? ?</el-icon>
? ?<el-icon :size="20">
? ? ? ?<search></search>
? ?</el-icon>
</template>
<script setup lang="ts">
</script>
全局导入
推荐添加
// tsconfig.json
{
?"compilerOptions": {
? ?// ...
? ?"types": ["element-plus/global"]
}
}
安装
npm install element-plus --save
# or
yarn add element-plus
?
# 安装icon图标依赖库
npm install @element-plus/icons
# or
yarn add @element-plus/icons
在main.ts 文件中全局配置
import { createApp } from 'vue'
import App from './App.vue'
import { store, key } from './store';
// 注入路由
import router from './router';
?
// 全局引入ui库
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
?
const app = createApp(App);
app.use(store, key);
app.use(router);
app.use(ElementPlus);
app.mount('#app');
使用ui组件
使用图标,因为图标和普通ui组件不是同一个包,使用需要分别导入
//导入具体的组件后直接使用
<template>
? ?<el-icon :size="20" :color="'blue'">
? ? ? ?<edit />
? ?</el-icon>
</template>
<script setup lang="ts">
? ?import { Edit } from '@element-plus/icons'
</script>
将图标库在main.ts文件中impott并使用app.component()注册便可以直接在组件中使用了,和普通的使用ui库同理
<template>
<h2>home页面</h2>
? ?<el-button type="primary" >主要按钮</el-button>
? ?<el-button type="success" >成功按钮</el-button>
? ?<el-icon :size="20" :color="'blue'">
? ? ? ?<edit />
? ?</el-icon>
? ?<el-icon :size="20">
? ? ? ?<search></search>
? ?</el-icon>
</template>
<script setup lang="ts">
</script>
来源:https://juejin.cn/post/7017103423107497992
标签:element-plus,按需导入,全局导入
0
投稿
猜你喜欢
django 发送邮件和缓存的实现代码
2021-05-09 20:53:09
匿名函数的写法
2010-01-06 13:32:00
PHP PDO函数库(PDO Functions)第1/2页
2024-05-08 09:38:45
Python自定义进程池实例分析【生产者、消费者模型问题】
2023-05-20 12:20:02
ASP编程入门进阶(十):Global.asa文件
2008-07-12 07:05:00
tensorflow 1.X迁移至tensorflow2 的代码写法
2023-07-19 08:30:54
不通过数据源名DSN也能访问Access数据库吗?
2009-10-29 12:22:00
Python数据分析之matplotlib绘图详解
2022-11-21 16:34:30
pygame实现非图片按钮效果
2021-08-30 23:21:14
Thinkphp5框架实现获取数据库数据到视图的方法
2024-05-03 15:52:16
MySQL表设计优化与索引 (八)
2010-10-25 19:46:00
Ruby序列化和持久化存储(Marshal、Pstore)操作方法详解
2024-04-26 17:20:16
Linux安装Python3.8.1的教程详解
2022-03-26 10:43:24
JavaScript substr() 字符串截取函数使用详解
2024-06-05 09:55:13
python时间序列按频率生成日期的方法
2021-10-04 22:38:40
深入了解Python中Lambda函数的用法
2023-02-03 10:09:01
python在地图上画比例的实例详解
2023-06-22 20:54:00
pycharm设置虚拟环境与更换镜像教程
2023-06-10 06:58:05
新兴XML处理方法VTD-XML介绍
2008-09-04 14:42:00
SQL优化老出错,那是你没弄明白MySQL解释计划用法
2024-01-27 16:13:43