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
  • asp之家 网络编程 m.aspxhome.com