《ElementPlus 与 ElementUI 差异集合》icon 图标使用(包含:el-button,el-input和el-dropdown 差异对比)
安装
注意 ElementPlus
的 Icon 图标
要额外安装插件 @element-plus/icons-vue
.
npm install @element-plus/icons-vue
注册
全局注册
定义一个文件 element-icon.js
,注意代码第 6
行。加上了前缀 ElIcon
,避免组件命名重复,且易于理解为 element-plus
的 icon
。
import * as ElementPlusIconsVue from '@element-plus/icons-vue'export const registerElIcon = (app) => {// 全局注册图标 ElIconXxxxfor (let i in ElementPlusIconsVue) {let name = `ElIcon${i}`;app.component(name, ElementPlusIconsVue[i])}
}
main.js
中引入
import { registerElIcon } from './elements-icon.js'// 全局注册 el-icon
registerElIcon(app);
局部注册
在组件内局部注册,这里使用 <script setup>
。
<script setup>
import {Postcard as ElIconPostcard,Calendar as ElIconCalendar,
} from '@element-plus/icons-vue'
</script>
使用
全局或局部注册的使用方式是一样的。使用方式也有两种,且注意接下来的使用都是加了前缀 el-icon-xxx
或 ElIconXxxx
。
方式一:结合 el-icon 使用
使用 el-icon
为 SVG
图标提供属性
<!-- 小驼峰方式 -->
<el-icon :size="size" :color="color"><el-icon-edit />
</el-icon><!-- 大驼峰方式 -->
<el-icon :size="size" :color="color"><ElIconEdit />
</el-icon>
方式二:直接使用 SVG 图标
<!-- 小驼峰方式 -->
<el-icon-edit /><!-- 大驼峰方式 -->
<ElIconEdit />
与 ElementUI 的区别
el-button
element-ui
el-button 中的icon
使用,属性icon
是图标类名,类型是string
;element-plus
el-button 中的icon
使用,属性icon
图标组件,类型是string /Component
;
element-ui
方式 1:class=“el-icon-xxx” 类名
如图蓝色框是图标,文字标签 <span>
包裹图标标签 <i class="el-icon-xxx">
。
<el-button size="mini" type="text" ><i class="el-icon-folder-add"></i>新建1
</el-button>
方式 2:el-button icon 属性
如图蓝色框是图标,文字标签 <span>
与图标标签 <i class="el-icon-xxx">
同级。
<el-button size="mini" type="text" icon="el-icon-folder-add">新建2
</el-button>
element-plus
以下 icon
组件都是加了前缀 ElIconXxxx
和 el-icon-xxx
1. icon 组件方式
无论
icon
是全局或局部注册,在el-button
中的使用方式都是一样的。
方式 1:直接使用 SVG
图标
如图蓝色框是图标,直接渲染 <svg>
标签。
<!-- 方式1:直接使用 SVG 图 -->
<el-button size="small" type="primary" link ><ElIconFolderAdd/>新建1
</el-button>
方式 2:结合 el-icon
使用
如图蓝色框是图标,且被标签 <i class="el-icon">
包裹一层。
<!-- 方式2:结合 `el-icon` 使用 -->
<el-button size="small" type="primary" link ><el-icon><ElIconFolderAdd/></el-icon>新建2
</el-button>
2.el-button icon 属性方式
此处有坑!!!
icon
的全局和局部组件注册,在el-button
中使用 icon 属性有差异!
方式 1:el-button 属性 icon 为 Component 类型
局部注册有效,全局注册无效!
- 使用
el-button
属性icon
; - 局部注册,在可以找到属性
icon
的组件对象; - 全局注册,无法找到
icon
的组件对象,所以渲染失败; html
把文字标签<span>
与标签<i class="el-icon">
渲染为同级;
<!-- 局部注册,注意 icon 前有 : -->
<el-button size="small" type="primary" link :icon="ElIconFolderAdd">新建3
</el-button>
方式 2:el-button 属性 icon 为 string 类型
全局注册有效,局部注册无效!
- 使用
el-button
属性icon
,且没有:
; - 全局注册,识别为全局注册的组件名称;
- 局部注册,找不到组件名称,所以渲染失败;
- **小技巧:**代码第 6 行,也可写成小驼峰。这样就和
ElementUI
方式2 一致了 ; html
把文字标签<span>
与标签<i class="el-icon">
渲染为同级;
此方式无效。注意 icon
前没有 :
,传入是 string 类型,组件无法被识别。
<!-- 全局注册:注意 icon 前没有 : -->
<el-button size="small" type="primary" link icon="ElIconFolderAdd">新建4
</el-button>
<!-- 全局注册:注意 icon 前没有 : -->
<el-button size="small" type="primary" link icon="el-icon-folder-add">新建5
</el-button>
el-input
-
element-ui
el-input 中的icon
使用,属性前缀prefix-icon
或后缀suffix-icon
是图标类名,类型是string
; -
element-plus
el-input 中的icon
使用,属性前缀prefix-icon
或后缀suffix-icon
是图标类名,图标组件,类型是string /Component
;
element-ui
有两种方式:
- 属性方式:使用前缀
prefix-icon
和后缀suffix-icon
; slot
方式:使用前缀prefix
和后缀suffix
;
<!-- 属性方式 -->
<el-input placeholder="请输入内容" prefix-icon="el-icon-search" v-model="inputVal"></el-input> <!-- slot 方式 -->
<el-input placeholder="请输入内容" v-model="inputVal"><i slot="prefix" class="el-input__icon el-icon-search"></i>
</el-input>
element-plus
这里不再赘述 icon 组件的全局注册和局部注册的差异。与 el-button 同理。
同样有两种方式。:
- 属性方式:使用前缀
prefix-icon
和后缀suffix-icon
; slot
方式:使用前缀#prefix
和后缀#suffix
;
<!-- 属性方式,且局部注册,类型为 Component,有 : -->
<el-input placeholder="请输入内容" :prefix-icon="ElIconSearch" v-model="inputVal" /><!-- 属性方式,全局部注册,类型为 string。没有 : -->
<el-input placeholder="请输入内容" prefix-icon="ElIconSearch" v-model="inputVal" /><!-- 属性方式,全局部注册,类型为 string。没有 : 小驼峰 -->
<el-input placeholder="请输入内容" prefix-icon="el-icon-search" v-model="inputVal" /><!-- slot 方式 -->
<el-input placeholder="请输入内容" v-model="inputVal"><template #prefix><el-icon class="el-input__icon"><ElIconSearch/></el-icon></template>
</el-input>
el-dropdown
这里不再赘述 icon 组件的全局注册和局部注册的差异。与 el-button 同理。
-
element-ui
el-dropdown 中的icon
使用 -
element-plus
el-dropdown 中的icon
使用
element-ui
使用属性 icon
方式。
<el-dropdown-menu><el-dropdown-item command="about" icon="el-icon-setting">关于</el-dropdown-item><el-dropdown-item command="theme" icon="el-icon-data-analysis">主题</el-dropdown-item><el-dropdown-item command="logout" icon="el-icon-switch-button">注销</el-dropdown-item>
</el-dropdown-menu>
element-plus
使用属性 icon
方式。
<el-dropdown-menu><!-- 属性方式,且局部注册,类型为 Component,有 : --><el-dropdown-item command="admin" :icon="ElIconSetting">后台管理</el-dropdown-item><!-- 属性方式,全局部注册,类型为 string。没有 : --><el-dropdown-item command="theme" icon="ElIconDataAnalysis">切换主题</el-dropdown-item><!-- 属性方式,全局部注册,类型为 string。没有 : 小驼峰 --><el-dropdown-item command="logout" :con="el-icon-switch-button">注销</el-dropdown-item>
</el-dropdown-menu>
相关文章:

《ElementPlus 与 ElementUI 差异集合》icon 图标使用(包含:el-button,el-input和el-dropdown 差异对比)
安装 注意 ElementPlus 的 Icon 图标 要额外安装插件 element-plus/icons-vue. npm install element-plus/icons-vue注册 全局注册 定义一个文件 element-icon.js ,注意代码第 6 行。加上了前缀 ElIcon ,避免组件命名重复,且易于理解为 e…...
力扣题库第8题:去重后的最长子串
题目: 给定一个字符串 s ,请你找出其中不含有重复字符的 最长 子串的长度。 示例 1: 输入: s "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。 示例 2: 输入: s "bbbbb" …...
CSS样式中长度单位含义解析:rpx、px、vw、vh、em、rem、pt
在 CSS 样式中,有几种常见的长度单位,包括 rpx 、 px 、 vw 和 vh 等,含义解析如下: 1 . rpx (响应像素): 是微信小程序中的一种相对长度单位,可以根据屏幕宽度进行自适应缩放。 1rp…...

全国车辆识别代码信息API查询接口-VIN深度解析
我们先来介绍下什么是vin码,以及vin码的构成结构解析,汽车VIN码,也叫车辆识别号码,通俗可以理解为汽车的身份证号码。 VIN码一共分四大部分: 1~3位,是世界制造厂识别代号(WMI)&…...
python django 模型中字段设置blank, null属性值用法说明
问题1: ShareUser models.CharField(max_length128, blankTrue) blank设置True和false分别代表什么含义, 有什么区别?chatgpt回答的答案如下: 在 Django 模型字段中,blank 参数用于指定在创建对象时该字段是否可以为空值。它的含义如下: blankTrue:…...
暴雨信息:可持续转型更需要“以人为本”
数字化正在开启新的商业模式和价值流,为企业与组织带来巨大收益。其中,“人 (People)”这一因素至关重要。 提供更好的工作与生活体验,应对人口老龄化、劳动力短缺等挑战。对于企业而言,解决这些问题既是社会责任,也是…...

1.2_3 TCP/IP参考模型
文章目录 1.2_3 TCP/IP参考模型(一)OSI参考模型与TCP/IP参考模型(二)5层参考模型(三)5层参考模型的数据封装与解封装 1.2_3 TCP/IP参考模型 (一)OSI参考模型与TCP/IP参考模型 TCP/I…...

真空泵系统数据采集远程监控解决方案
行业背景 半导体制造业可以说是现代电子工业的核心产业,广泛应用于计算机、通信、汽车、医疗等领域。而在半导体生产加工过程中,如刻蚀、 镀膜、 扩散、沉积、退火等环节,真空泵都是必不可少的关键设备,它可以构建稳定受控的真空…...

Python语言在编程业界的地位——《跟老吕学Python编程》附录资料
Python语言在编程业界的地位——《跟老吕学Python编程》附录资料 ⭐️Python语言在编程业界的地位2024年3月编程语言排行榜(TIOBE前十) ⭐️Python开发语言开发环境介绍1.**IDLE**2.⭐️PyCharm3.**Anaconda**4.**Jupyter Notebook**5.**Sublime Text** …...

基于Redis自增实现全局ID生成器(详解)
本博客为个人学习笔记,学习网站与详细见:黑马程序员Redis入门到实战 P48 - P49 目录 全局ID生成器介绍 基于Redis自增实现全局ID 实现代码 全局ID生成器介绍 背景介绍 当用户在抢购商品时,就会生成订单并保存到数据库的某一张表中&#…...
hadoop 总结
1.hadoop 配置文件 core-site hdfs-site yarn-site.xml worker hdfs-site.xml <?xml version"1.0" encoding"UTF-8"?> <?xml-stylesheet type"text/xsl" href"configuration.xsl"?> <configuration><pr…...

luatos框架中LVGL如何使用中文字体〈二〉编写脚本设置中文字体
本节内容,将和大家一同学习,在luatos环境中,使用lvgl库,一步步的编译固件、编写脚本,最终实现中文字体的显示。 芯片:AIR101 LCD屏:ST7789 上一节,我们一同学习了,硬件引…...
c++单例模式和call_once函数
单例模式是一种常见的设计模式,用于确保某个类只能创建一个实例。由于单例模式是全局唯一的,因此在多线程中使用单例模式时需要考虑线程安全问题。 1.GetInstance()实例化一个对象 懒汉式:第一次用到类的时候才会去实例化。 懒汉式创建对象…...

AutoMQ 携手阿里云共同发布新一代云原生 Kafka,帮助得物有效压缩 85% Kafka 云支出!
3 月 9 日,“AutoMQ x 阿里云云原生创新论坛”在阿里巴巴西溪园区圆满落幕。本次论坛现场不仅重磅发布了新一代云原生 Kafka 产品(AutoMQ On-Prem 版),还邀请了来自得物的稳定生产负责人分享 AutoMQ 在生产场景中的应用实践&…...

力扣977. 有序数组的平方
思路:暴力法:全部平方,然后调用排序API,排序算法最快是N*log(N)时间复制度。 双指针法:要利用好原本的数组本就是有序的数组这个条件, 只是有负数 导致平方后变大了,那么平方后的最大值就是在两…...
VSCode设置
VSCode设置 VSCode设置1.双击和点击显示设置2.快捷键设置 VSCode设置 1.双击和点击显示设置 VSCode设置双击才能打开文件、文件夹 打开文件夹:在设置页中搜索 expandMode,将 singleClick 改为 doubleClick 即可。 双击打开文件:在设置页中搜索workben…...

2.2 评估方法 机器学习
我们若有一个包含m个样例的数据集,若我们既需要训练,也需要测试,我们该如何处理呢?下面是几种方法: 2.2.1 留出法 “留出法”直接将数据集D划分为两个互斥的集合,其中一个作为训练集S,另一个作…...

第一类换元法(凑微分,凑狗)【高数笔记】
1.第一类换元法,解决的是什么类型的问题 2.不同的问题,应该有什么解法 3.13个基本积分公式,应该注意什么...

PostgreSQL数据库优化指南
默认安装下的 PostgreSQL 配置无法完全利用现有硬件,影响Netbox的性能。 本文章讲解了如何简单去优化。 优化 项目地址:https://github.com/le0pard/pgtune 首先打开:https://pgtune.leopard.in.ua/ (此网站会根据你的选择自动生成优化配置…...

VScode Error Lens插件
安装完成之后,当我们输入一些错误的语法格式的时候,它都会有一些提示! 一开始是英文提示 修改为中文提示 设置搜索 typescript.local...

超短脉冲激光自聚焦效应
前言与目录 强激光引起自聚焦效应机理 超短脉冲激光在脆性材料内部加工时引起的自聚焦效应,这是一种非线性光学现象,主要涉及光学克尔效应和材料的非线性光学特性。 自聚焦效应可以产生局部的强光场,对材料产生非线性响应,可能…...

【kafka】Golang实现分布式Masscan任务调度系统
要求: 输出两个程序,一个命令行程序(命令行参数用flag)和一个服务端程序。 命令行程序支持通过命令行参数配置下发IP或IP段、端口、扫描带宽,然后将消息推送到kafka里面。 服务端程序: 从kafka消费者接收…...
<6>-MySQL表的增删查改
目录 一,create(创建表) 二,retrieve(查询表) 1,select列 2,where条件 三,update(更新表) 四,delete(删除表…...

无法与IP建立连接,未能下载VSCode服务器
如题,在远程连接服务器的时候突然遇到了这个提示。 查阅了一圈,发现是VSCode版本自动更新惹的祸!!! 在VSCode的帮助->关于这里发现前几天VSCode自动更新了,我的版本号变成了1.100.3 才导致了远程连接出…...
多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验
一、多模态商品数据接口的技术架构 (一)多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如,当用户上传一张“蓝色连衣裙”的图片时,接口可自动提取图像中的颜色(RGB值&…...
Neo4j 集群管理:原理、技术与最佳实践深度解析
Neo4j 的集群技术是其企业级高可用性、可扩展性和容错能力的核心。通过深入分析官方文档,本文将系统阐述其集群管理的核心原理、关键技术、实用技巧和行业最佳实践。 Neo4j 的 Causal Clustering 架构提供了一个强大而灵活的基石,用于构建高可用、可扩展且一致的图数据库服务…...
【RockeMQ】第2节|RocketMQ快速实战以及核⼼概念详解(二)
升级Dledger高可用集群 一、主从架构的不足与Dledger的定位 主从架构缺陷 数据备份依赖Slave节点,但无自动故障转移能力,Master宕机后需人工切换,期间消息可能无法读取。Slave仅存储数据,无法主动升级为Master响应请求ÿ…...
关于 WASM:1. WASM 基础原理
一、WASM 简介 1.1 WebAssembly 是什么? WebAssembly(WASM) 是一种能在现代浏览器中高效运行的二进制指令格式,它不是传统的编程语言,而是一种 低级字节码格式,可由高级语言(如 C、C、Rust&am…...
安卓基础(aar)
重新设置java21的环境,临时设置 $env:JAVA_HOME "D:\Android Studio\jbr" 查看当前环境变量 JAVA_HOME 的值 echo $env:JAVA_HOME 构建ARR文件 ./gradlew :private-lib:assembleRelease 目录是这样的: MyApp/ ├── app/ …...

MyBatis中关于缓存的理解
MyBatis缓存 MyBatis系统当中默认定义两级缓存:一级缓存、二级缓存 默认情况下,只有一级缓存开启(sqlSession级别的缓存)二级缓存需要手动开启配置,需要局域namespace级别的缓存 一级缓存(本地缓存&#…...