《ElementPlus 与 ElementUI 差异集合》icon 图标使用(包含:el-button,el-input和el-dropdown 差异对比)

安装

注意 ElementPlusIcon 图标 要额外安装插件 @element-plus/icons-vue.

npm install @element-plus/icons-vue

注册

全局注册

定义一个文件 element-icon.js ,注意代码第 6 行。加上了前缀 ElIcon ,避免组件命名重复,且易于理解为 element-plusicon

import * as ElementPlusIconsVue from '@element-plus/icons-vue'

export const registerElIcon = (app) => {
    // 全局注册图标 ElIconXxxx
    for (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-xxxElIconXxxx

方式一:结合 el-icon 使用

使用 el-iconSVG 图标提供属性

<!-- 小驼峰方式 -->
<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 组件都是加了前缀 ElIconXxxxel-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

有两种方式:

  1. 属性方式:使用前缀 prefix-icon 和后缀 suffix-icon
  2. 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 同理。

同样有两种方式。:

  1. 属性方式:使用前缀 prefix-icon 和后缀 suffix-icon
  2. 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>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/453791.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

深入解析C++树形关联式容器:map、set及其衍生容器的使用与原理

文章目录 一、引言二、关联式容器的中的 paira.pair 的创建及使用b.pair 间的比较 三、 map 与 set 详解1. map 的基本操作2. set 的基本操作3.关联式容器的迭代器 四、 multimap 与 multiset 的特性五、关联式容器的使用技巧与注意事项1. 键值类型的选择与设计2. 自定义比较函…

openGauss学习笔记-241 openGauss性能调优-SQL调优-审视和修改表定义

文章目录 openGauss学习笔记-241 openGauss性能调优-SQL调优-审视和修改表定义241.1 审视和修改表定义概述241.2 选择存储模型241.3 使用局部聚簇241.4 使用分区表241.5 选择数据类型 openGauss学习笔记-241 openGauss性能调优-SQL调优-审视和修改表定义 241.1 审视和修改表定…

R语言复现:如何利用logistic逐步回归进行影响因素分析?

Logistic回归在医学科研、特别是观察性研究领域&#xff0c;无论是现况调查、病例对照研究、还是队列研究中都是大家经常用到的统计方法&#xff0c;而在影响因素研究筛选自变量时&#xff0c;大家习惯性用的比较多的还是先单后多&#xff0c;P&#xff1c;0.05纳入多因素研究&…

【深度学习笔记】8_2 异步计算

注&#xff1a;本文为《动手学深度学习》开源内容&#xff0c;部分标注了个人理解&#xff0c;仅为个人学习记录&#xff0c;无抄袭搬运意图 8.2 异步计算 此节内容对应的内容有兴趣的可以去看看原文。 今天的计算机是高度并行的系统&#xff0c;由多个CPU核、多个GPU、多个处…

yolov5模型压缩-torch_pruning

参考论文:DepGraph: Towards Any Structural Pruning(https://arxiv.org/abs/2301.12900) 主要原理:物理的移除参数,并自动找出层与层以及层之间的依赖,完成模型的自动裁剪 模型压缩效果:yolov5剪枝流程如下: pip install torch_pruning 新建prune.py: import torch_…

AppLink对51Tracking的集成方式

什么是51Tracking 51Tracking是一个提供国际物流跟踪服务的平台&#xff0c;用户可以通过该平台跟踪包裹在全球范围内的物流信息。该平台提供多家物流公司的跟踪服务&#xff0c;帮助用户更方便地了解包裹的运输情况和到达时间。提供实时运单查询、运单管理功能&#xff0c;支…

echarts绘制雷达图

<template><div><div>【云端报警风险】</div><div ref"target" class"w-full h-full" stylewidth&#xff1a;200px;height:300px></div></div> </template><script setup> import { ref, onMounte…

找视频素材软件去哪个app?推荐做短视频必备的几款APP!

做短视频的小伙伴们&#xff0c;有没有遇到过找不到合适素材的烦恼呢&#xff1f;有时候脑子里有好创意&#xff0c;却因为找不到合适的素材而搁置。 今天&#xff0c;我就来给大家推荐几个超实用的视频素材app&#xff0c;帮你的创意加加油&#xff01; 1. 蛙学网材网 首先要…

机器视觉检测设备的组成要素

机器视觉检测设备是一种先进的自动化检测技术工具&#xff0c;它利用光学、图像处理和计算机硬件及软件技术模拟并扩展人类的视觉功能&#xff0c;以实现对产品或目标物体进行自动化的尺寸测量、缺陷检测、表面质量评估、颜色识别、形状匹配以及位置判断等功能。这种设备通常包…

APP测试基本流程以及APP测试要点

一、 APP测试基本流程 1、流程图 2、测试周期 测试周期可按项目的开发周期来确定测试时间&#xff0c;一般测试时间为两三周&#xff08;即15个工作日&#xff09;&#xff0c;根据项目情况以及版本质量可适当缩短或延长测试时间。 3、测试资源 测试任务开始前&#xff0c;…

如何在群晖NAS部署WPS容器并实现无公网IP远程访问本地office软件

文章目录 1. 拉取WPS Office镜像2. 运行WPS Office镜像容器3. 本地访问WPS Office4. 群晖安装Cpolar5. 配置WPS Office远程地址6. 远程访问WPS Office小结 7. 固定公网地址 wps-office是一个在Linux服务器上部署WPS Office的镜像。它基于WPS Office的Linux版本&#xff0c;通过…

案例分析篇09:Web架构设计相关20个考点(7~11)(2024年软考高级系统架构设计师冲刺知识点总结)

专栏系列文章推荐: 2024高级系统架构设计师备考资料(高频考点&真题&经验)https://blog.csdn.net/seeker1994/category_12593400.html 【历年案例分析真题考点汇总】与【专栏文章案例分析高频考点目录】(2024年软考高级系统架构设计师冲刺知识点总结-案例分析篇-…

TimescaleDB 安装部署

文章目录 1.Yum安装TimescaleDB1.1.安装PostgreSQL1.2.安装Timescaledb插件1.3.创建Timescaledb扩展 2.Docker安装Timescaledb 开源中间件 # TimescaleDBhttps://iothub.org.cn/docs/middleware/ https://iothub.org.cn/docs/middleware/timescale/timescale-deploy/1.Yum安装…

Rabbit算法:轻量高效的加密利器

title: Rabbit算法&#xff1a;轻量高效的加密利器 date: 2024/3/13 18:14:31 updated: 2024/3/13 18:14:31 tags: Rabbit算法流密码高安全性高性能密钥调度加密解密抗攻击性 Rabbit算法起源&#xff1a; Rabbit算法是由Martin Boesgaard和Mette Vesterager提出的一种流密码算…

1.获取DOM对象、操作元素内容、操作元素属性、自定义属性、定时器

web Api基本认知 作用&#xff1a;通过JS去操作html页面和浏览器(实现浏览器中的某些功能) 分类&#xff1a; DOM(网页)&#xff1a;Document Object Model(文档对象模型) BOM(浏览器)&#xff1a;Borwser Object Model(浏览器对象模型) DOM DOM树 将网页中标签的关系以树状…

【考研学子必看 ★2024考研国家线及调剂策略(2)】

----------------------------------------------------------------------------------------------------- 考研复试科研背景提升班 教你快速深入了解掌握考研复试面试中的常见问题以及注意事项&#xff0c;系统的教你如何在短期内快速提升自己的专业知识水平和编程以及英语…

【性能测试】移动测试md知识总结第1篇:移动端测试课程介绍【附代码文档】

移动测试完整教程&#xff08;附代码资料&#xff09;主要内容讲述&#xff1a;移动端测试课程介绍&#xff0c;移动端测试知识概览&#xff0c;移动端测试环境搭建&#xff0c;ADB常用命令学习主要内容,学习目标,学习目标,1. window安装andorid模拟器,学习目标。主流移动端自动…

【c++修仙】c语言练气第九重动态内存管理

为什么要有动态内存 例如 int a20 char arr[10]{10}; 这些的内存是固定的 但是有时候我们需要的空间大小是在程序运行的时候才能知道的 malloc和free void* malloc (size_t size) 这个函数向内存申请一块连续可用的空间&#xff0c;并返回指向这块空间的指针。 如果开辟…

环信ChatroomUIKit功能详解——超详细介绍

聊天室是当下泛娱乐社交应用中最经典的玩法&#xff0c;通过调用环信的 IM SDK 接口&#xff0c;可以快速创建聊天室。如果想根据自己业务需求对聊天室应用的 UI界面、弹幕消息、礼物打赏系统等进行自定义设计&#xff0c;最高效的方式则是使用环信的 ChatroomUIKit 。 文档地址…

抓包工具fiddler的使用

问题查询 定位bug是前端的问题还是后端的问题&#xff1f; 1.如果抓不到请求&#xff0c;显然就是前端的问题 2.如果有请求但是没有相应&#xff0c;那就是后端的问题 3.如果有请求也有相应&#xff0c;需要查看响应信息&#xff0c;如果返回报错了&#xff0c;则需要具体分析报…