Element Plus 实例详解(二)___Button 按钮

文章目录:

一、前言

二、搭建Element Plus试用环境

1、搭建Vue3项目(基于Vite + Vue)

2、安装Element Plus

三、Element Plus Button 按钮功能试用

1、Button 按钮组件基础用法

2、Button 按钮组件禁用状态

3、图标按钮

4、链接按钮

5、文字按钮

6、按钮组

7、加载状态按钮

8、调整尺寸

9、自定义颜色

四、官方资料中的各参数说明

五、总结


一、前言

  Element Plus Basic 基础组件里Button 按钮,是常用的操作按钮,提供了Button 按钮的基础用法、Button 按钮禁用状态、链接按钮、文字按钮、图标按钮、按钮组等功能,本篇里我们一起来试用一下Element Plus的 Button 按钮组件。

二、搭建Element Plus试用环境

1、搭建Vue3项目(基于Vite + Vue)

  安装时请选择支持Typescript,本实例我安装在(C:\00program\vue\vuelearn\vueviteproject1)目录中,具体方法详见下面文章:

vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)https://blog.csdn.net/weixin_69553582/article/details/129630880

安装完成后打开浏览器:http://localhost:5173/  ,能正常显示以下页面:

2、安装Element Plus

  • NPM:npm install element-plus --save

详细参考:

Element Plus 实例详解系列(一)__安装设置https://blog.csdn.net/weixin_69553582/article/details/129701286

三、Element Plus Button 按钮功能试用

1、Button 按钮组件基础用法

  • 使用 type、plain、round 和 circle 来定义按钮的样式。

实现效果:

完整代码:


<script setup lang="ts">
import { ref } from 'vue'defineProps<{ msg: string }>()const count = ref(0)import {Check,Delete,Edit,Message,Search,Star,} from '@element-plus/icons-vue'</script><template><h1>{{ msg }}</h1><div class="card"><button type="button" @click="count++">count is {{ count }}</button><p>Edit<code>components/HelloWorld.vue</code> to test HMR</p></div><p>Check out<a href="https://vuejs.org/guide/quick-start.html#local" target="_blank">create-vue</a>, the official Vue + Vite starter</p><p>Install<a href="https://github.com/vuejs/language-tools" target="_blank">Volar</a>in your IDE for a better DX</p><p class="read-the-docs">Click on the Vite and Vue logos to learn more</p><el-row class="mb-4"><el-button>Default默认</el-button><el-button type="primary">主要</el-button><el-button type="success">成功</el-button><el-button type="info">信息</el-button><el-button type="warning">警告</el-button><el-button type="danger">危险</el-button></el-row><br /><el-row class="mb-4"><el-button plain>Plain普通 </el-button><el-button type="primary" plain>主要</el-button><el-button type="success" plain>成功</el-button><el-button type="info" plain>信息</el-button><el-button type="warning" plain>警告</el-button><el-button type="danger" plain>危险</el-button></el-row><br /><el-row class="mb-4"><el-button round>Round圆</el-button><el-button type="primary" round>主要</el-button><el-button type="success" round>成功</el-button><el-button type="info" round>信息</el-button><el-button type="warning" round>警告</el-button><el-button type="danger" round>危险</el-button></el-row><br /><el-row><el-button :icon="Search" circle /><el-button type="primary" :icon="Edit" circle /><el-button type="success" :icon="Check" circle /><el-button type="info" :icon="Message" circle /><el-button type="warning" :icon="Star" circle /><el-button type="danger" :icon="Delete" circle /></el-row></template><style scoped>
.read-the-docs {color: #888;
}
</style>

2、Button 按钮组件禁用状态

  • 使用 disabled 属性来定义按钮是否被禁用。
  • 该属性接受一个 Boolean 类型的值。

实现效果:按钮呈现不可选的状态,鼠标在按钮上时,指针变成红色禁止符号

完整代码:

<script setup lang="ts">import { ref } from 'vue'import {Check,Delete,Edit,Message,Search,Star,} from '@element-plus/icons-vue'</script><template><el-row class="mb-4"><el-button disabled>Default默认</el-button><el-button type="primary" disabled>主要</el-button><el-button type="success" disabled>成功</el-button><el-button type="info" disabled>信息</el-button><el-button type="warning" disabled>警告</el-button><el-button type="danger" disabled>危险</el-button></el-row><br /><el-row class="mb-4"><el-button plain disabled>Plain普通 </el-button><el-button type="primary" plain disabled>主要</el-button><el-button type="success" plain disabled>成功</el-button><el-button type="info" plain disabled>信息</el-button><el-button type="warning" plain disabled>警告</el-button><el-button type="danger" plain disabled>危险</el-button></el-row><br /><el-row class="mb-4"><el-button round disabled>Round圆</el-button><el-button type="primary" round disabled>主要</el-button><el-button type="success" round disabled>成功</el-button><el-button type="info" round disabled>信息</el-button><el-button type="warning" round disabled>警告</el-button><el-button type="danger" round disabled>危险</el-button></el-row><br /><el-row><el-button :icon="Search" circle disabled/><el-button type="primary" :icon="Edit" circle disabled/><el-button type="success" :icon="Check" circle disabled/><el-button type="info" :icon="Message" circle disabled/><el-button type="warning" :icon="Star" circle disabled/><el-button type="danger" :icon="Delete" circle disabled/></el-row></template><style scoped>.read-the-docs {color: #888;}
</style>

3、图标按钮

  • 使用 icon 属性来为按钮添加图标。
  • 可以在 Icon 组件中找到所需图标。 通过向右方添加<i>标签来添加图标, 也可以使用自定义图标。
  • 可以单独使用图标不添加文字来节省显示区域占用。

实现效果:

完整代码:

<template><div class="flex"><el-button type="primary" :icon="Edit" /><el-button type="primary" :icon="Share" /><el-button type="primary" :icon="Delete" /><el-button type="primary" :icon="Search">查找</el-button><el-button type="primary">上传<el-icon class="el-icon--right"><Upload /></el-icon></el-button><br /><br /><el-row><el-button :icon="Search" circle /><el-button type="primary" :icon="Edit" circle /><el-button type="success" :icon="Check" circle /><el-button type="info" :icon="Message" circle /><el-button type="warning" :icon="Star" circle /><el-button type="danger" :icon="Delete" circle /></el-row></div>
</template>
<script setup lang="ts">import { Check,Message,Star,Delete, Edit, Search, Share, Upload } from '@element-plus/icons-vue'
</script>

4、链接按钮

WARNING

  • type="text" 已被 废弃,将于版本3.0.0 时 移除。
  • 新的 API link 于2.2.1 版本添加,同时可以使用 type API 设置链接按钮的主题样式。

实现效果:

完整代码:

<template><h3>“基本链接”按钮</h3><div class="flex justify-space-between mb-4 flex-wrap gap-4"><el-button v-for="button in buttons":key="button.text":type="button.type"link>{{ button.text }}</el-button></div><br /><h3>“已禁用的链接”按钮</h3><div class="flex justify-space-between flex-wrap gap-4"><el-button v-for="button in buttons":key="button.text":type="button.type"linkdisabled>{{ button.text }}</el-button></div>
</template><script setup lang="ts">const buttons = [{ type: '', text: 'plain普通' },{ type: 'primary', text: 'primary主要' },{ type: 'success', text: 'success成功' },{ type: 'info', text: 'info信息' },{ type: 'warning', text: 'warning警告' },{ type: 'danger', text: 'danger危险' },] as const
</script>

5、文字按钮

  • 2.2.0 如果您想要使用老版样式的按钮,可以考虑使用 Link 组件。、
  • type 属性会同时控制按钮的样式, 因此新的 API text: boolean 来控制文字按钮。
  • 没有边框和背景色的按钮。

实现效果:

完整代码:

<template><h3>“基本文本”按钮</h3><div class="flex justify-space-between mb-4 flex-wrap gap-4"><el-button v-for="button in buttons":key="button.text":type="button.type"text>{{ button.text }}</el-button></div><br /><br /><h3>背景颜色始终开启</h3><div class="flex justify-space-between mb-4 flex-wrap gap-4"><el-button v-for="button in buttons":key="button.text":type="button.type"textbg>{{ button.text }}</el-button></div><br /><br /><h3>禁用的文本按钮</h3><div class="flex justify-space-between flex-wrap gap-4"><el-button v-for="button in buttons":key="button.text":type="button.type"textdisabled>{{ button.text }}</el-button></div>
</template><script setup lang="ts">const buttons = [{ type: '', text: 'plain普通' },{ type: 'primary', text: 'primary主要' },{ type: 'success', text: 'success成功' },{ type: 'info', text: 'info信息' },{ type: 'warning', text: 'warning警告' },{ type: 'danger', text: 'danger危险' },] as const
</script>

6、按钮组

实现效果:

完整代码:

<template><el-button-group><el-button type="primary" :icon="ArrowLeft">上一页</el-button><el-button type="primary">下一页<el-icon class="el-icon--right"><ArrowRight /> </el-icon></el-button></el-button-group><br /><br /><el-button-group class="ml-4"><el-button type="primary" :icon="Edit"  circle/> <el-button type="primary" :icon="Share"  circle/> <el-button type="primary" :icon="Delete"  circle/> </el-button-group>
</template><script setup lang="ts">import {ArrowLeft,ArrowRight,Delete,Edit,Share,} from '@element-plus/icons-vue'
</script>

7、加载状态按钮

实现效果:

完整代码:

<template><el-button type="primary" loading size="large">Loading</el-button><el-button type="primary" :loading-icon="Eleme" loading size="large" >Loading</el-button><el-button type="primary" loading size="large" ><template #loading><div class="custom-loading"><svg class="circular" viewBox="-10, -10, 50, 50"><path class="path"d="M 30 15L 28 17M 25.61 25.61A 15 15, 0, 0, 1, 15 30A 15 15, 0, 1, 1, 27.99 7.5L 15 15"style="stroke-width: 3px; fill: rgb(255, 216, 0)" /></svg></div></template>Loading</el-button>
</template><script lang="ts" setup>import { Eleme } from '@element-plus/icons-vue'
</script><style scoped>.el-button .custom-loading .circular {margin-right: 6px;width: 35px;height: 35px;animation: loading-rotate 2s linear infinite;}.el-button .custom-loading .circular .path {animation: loading-dash 1.5s ease-in-out infinite;stroke-dasharray: 90, 150;stroke-dashoffset: 0;stroke-width: 2;stroke: var(--el-button-text-color);stroke-linecap: round;}
</style>

8、调整尺寸

  • 除了默认的大小,按钮组件还提供了几种额外的尺寸可供选择,以便适配不同的场景。
  • 使用 size 属性额外配置尺寸,可使用 large和small两种值。

实现效果:

完整代码:

<template><el-row><el-button size="large">Large</el-button><el-button>Default</el-button><el-button size="small">Small</el-button></el-row><br /><el-row class="my-4"><el-button size="large" round>Large</el-button><el-button round>Default</el-button><el-button size="small" round>Small</el-button></el-row><br /><el-row><el-button size="large" :icon="Search">Search</el-button><el-button :icon="Search">Search</el-button><el-button size="small" :icon="Search">Search</el-button></el-row><br /><el-row class="my-4"><el-button size="large" :icon="Search" round>Search</el-button><el-button :icon="Search" round>Search</el-button><el-button size="small" :icon="Search" round>Search</el-button></el-row><br /><el-row><el-button :icon="Search" size="large" circle /><el-button :icon="Search" circle /><el-button :icon="Search" size="small" circle /></el-row>
</template><script setup lang="ts">import { Search } from '@element-plus/icons-vue'
</script>

9、自定义颜色

  • 可以自定义按钮颜色。
  • 系统将自动计算 hover 和 active 颜色。

实现效果:

完整代码:

<template><div class="flex"><el-button color="#E6005C" :dark="isDark" size="large">逆境清醒</el-button><el-button color="#00BFFF" :dark="isDark" plain size="large">逆境清醒</el-button><el-button color="#20B2AA" :dark="isDark" disabled size="large">逆境清醒</el-button><el-button color="#626aef" :dark="isDark" disabled plain size="large">逆境清醒</el-button></div>
</template>

四、官方资料中的各参数说明

Button API

Button Attributes

属性名 说明 类型 默认值
size 尺寸 enum
type 类型 enum
plain 是否为朴素按钮 boolean false
text2.2.0 是否为文字按钮 boolean false
bg2.2.0 是否显示文字按钮背景颜色 boolean false
link 2.2.1 是否为链接按钮 boolean false
round 是否为圆角按钮 boolean false
circle 是否为圆形按钮 boolean false
loading 是否为加载中状态 boolean false
loading-icon 自定义加载中状态图标组件 string / Component Loading
disabled 按钮是否为禁用状态 boolean false
icon 图标组件 string / Component
autofocus 原生 autofocus 属性 boolean false
native-type 原生 type 属性 enum button
auto-insert-space 自动在两个中文字符之间插入空格 boolean
color 自定义按钮颜色, 并自动计算 hoveractive 触发后的颜色 string
dark dark 模式, 意味着自动设置 color 为 dark 模式的颜色 boolean false

Button Slots

插槽名 说明
default 自定义默认内容
loading 自定义加载中组件
icon 自定义图标组件

Button Exposes

属性名 说明 类型
ref 按钮 html 元素 object
size 按钮尺寸 object
type 按钮类型 object
disabled 按钮已禁用 object
shouldAddSpace 是否在两个字符之间插入空格 object

ButtonGroup API

ButtonGroup Attributes

插槽名 说明 类型 默认值
size 用于控制该按钮组内按钮的大小 enum
type 用于控制该按钮组内按钮的类型 enum

ButtonGroup Slots

插槽名 说明 子标签
default 自定义按钮组内容 Button

五、总结

1

Element Plus 实例详解(一)__安装设置
2 Element Plus 实例详解(二)___Button 按钮
3 Element Plus 实例详解(三)___Date Picker 日期选择
4 Element Plus 实例详解(四)___Border 边框
5 Element Plus 实例详解(五)___Container 布局容器
6 Element Plus 实例详解(六)___Icon 图标
7 Element Plus 实例详解(七)___Layout 布局
8 Element Plus 实例详解(八)___Scrollbar 滚动条
9 Element Plus 实例详解(九)___Space 间距
10 Element Plus 实例详解(十)___Typography 排版
11 Element Plus 实例详解(十一)___

       推荐阅读:

30

​​

Vue3安装配置、开发环境搭建(组件安装卸载)(图文详细)
29 ​​​​​

SVG实例详解系列(一)(svg概述、位图和矢量图区别(图解)、SVG应用实例)

28 ​​​​​

查看jdk安装路径,在windows上实现多个java jdk的共存解决办法,安装java19后终端乱码的解决

27 ​​​​​

别具一格,原创唯美浪漫情人节表白专辑,(复制就可用)(html5,css3,svg)表白爱心代码(1)

26 ​​​​​

2023年春节祝福第二弹——送你一只守护兔,让它温暖每一个你【html5 css3】画会动的小兔子,炫酷充电,字体特

25 ​​​​​

2023春节祝福系列第一弹(上)(放飞祈福孔明灯,祝福大家身体健康)(附完整源代码及资源免费下载)

24 ​​​​​

HTML+CSS+svg绘制精美彩色闪灯圣诞树,HTML+CSS+Js实时新年时间倒数倒计时(附源代码)

23 ​​​​​

​草莓熊python绘图(春节版,圣诞倒数雪花版)附源代码

22 ​​​​​

【程序人生】卡塔尔世界杯元素python海龟绘图(附源代码),世界杯主题前端特效5个(附源码)

21 ​​​​​

python爱心源代码集锦(18款)

20 ​​​​​

巴斯光年python turtle绘图__附源代码

19 ​​​​​

Three.js实例详解___旋转的精灵女孩(附完整代码和资源)(一)

18 ​​​​​

​草莓熊python turtle绘图代码(玫瑰花版)附源代码

17 ​​​​​

立体多层玫瑰绘图源码__玫瑰花python 绘图源码集锦

16 ​​​​​

皮卡丘python turtle海龟绘图(电力球版)附源代码

15 ​​​​​

【CSDN云IDE】个人使用体验和建议(含超详细操作教程)(python、webGL方向)

14 ​​​​​

草莓熊python turtle绘图(风车版)附源代码

13 ​​​​​

用代码过中秋,python海龟月饼你要不要尝一口?

12 ​​​​​

《 Python List 列表全实例详解系列(一)》__系列总目录、列表概念

11 ​​​​​

用代码写出浪漫__合集(python、matplotlib、Matlab、java绘制爱心、玫瑰花、前端特效玫瑰、爱心)

10 ​​​​​

Python函数方法实例详解全集(更新中...)

9 ​​​​​

matplotlib 自带绘图样式效果展示速查(28种,全)

8 ​​​​​

手机屏幕坏了____怎么把里面的资料导出(18种方法)

7 ​​​​​

2023年3月TIOBE 指数头条:编程语言 Go 进入 TIOBE 指数前 10 名,多家权威机构____编程语言排行榜__薪酬状

6 ​​​​​

Python中Print()函数的用法___实例详解(全,例多)

5 ​​​​​

色彩颜色对照表(一)(16进制、RGB、CMYK、HSV、中英文名)

4 ​​​​​

Node.js (v19.1.0npm 8.19.3) vue.js安装配置教程(超详细)

3 ​​​​​

Tomcat 启动闪退问题解决集(八大类详细)

2 ​​​​​

Tomcat端口配置(详细)

1 ​​​​​

tomcat11、tomcat10 安装配置(Windows环境)(详细图文)

Element Plus 实例详解(二)___Button 按钮相关推荐

  1. Element Plus 实例详解(三)___Date Picker 日期选择

    Element Plus 实例详解(三) ___Date Picker 日期选择 文章目录: 一.前言 二.搭建Element Plus试用环境 1.搭建Vue3项目(基于Vite + Vue) 2. ...

  2. Element Plus 实例详解(一)___安装设置

    Element Plus 实例详解(一) ___安装设置 本篇目录: 一.前言 二.安装方法 1.环境支持 2.Element Plus安装使用方式 (1).使用包管理器 (2).浏览器直接引入 3. ...

  3. Element Plus 实例详解(四)___Border 边框

    Element Plus 实例详解(四)___Border 边框 本文目录: 一.前言 二.搭建Element Plus试用环境 1.搭建Vue3项目(基于Vite + Vue) 2.安装Elemen ...

  4. android按钮防止重复点击事件,实例详解Android解决按钮重复点击问题

    为了防止用户或者测试MM疯狂的点击某个button,写个方法防止按钮连续点击.具体实例代码如下所示: public class BaseActivity extends Activity { prot ...

  5. C#操作GridView控件绑定数据实例详解(二)

    上文实现的GridView控件: (一)翻页功能 翻页内容,主要实现的是该控件下面,上下翻页,跳转到指定页面. 翻页功能要注意前台页面下面这段代码中的相关命令: <PagerTemplate & ...

  6. Python中Print()函数的用法___实例详解(二)(全,例多)

    Python中Print()函数的用法___实例详解(二)(全,例多) 目录 十一.Print()小例子 十二.Print()中文输入显示乱码问题 十三.Print()写入文件 十四.print()在 ...

  7. android 中的悬浮按钮,Android 中FloatingActionButton(悬浮按钮)实例详解

    android 中floatingactionbutton(悬浮按钮)实例详解 一.介绍 这个类是继承自imageview的,所以对于这个控件我们可以使用imageview的所有属性 二.使用准备, ...

  8. solidworks api二次开发实例详解_Solidworks开发语言对比及分析

    很多初学Solidworks二次开发的同学,也许都会纠结使用何种语言进行二次开发.对于Solidworks二次开发的语言,官方有VBA,VB.NET,C#以及C++,四种语言. 用户通常会有如下疑问, ...

  9. python画二维散点图-基于python 二维数组及画图的实例详解

    1.二维数组取值 注:不管是二维数组,还是一维数组,数组里的数据类型要一模一样,即若是数值型,全为数值型 #二维数组 import numpy as np list1=[[1.73,1.68,1.71 ...

最新文章

  1. postgresql----文本搜索类型和检索函数
  2. 解题:USACO14OPEN Fair Photography
  3. 单E1光端机分类及技术指标详解
  4. 邻接表的两种实现(链表和数组模拟)
  5. 【LeetCode笔记】208. 实现Trie(前缀树)(Java、前缀树)
  6. Matlab适配器模式
  7. vue-cli目录结构解析
  8. 总结UIViewController的view在有navBar和tabBar影响下布局区域的问题
  9. Linux 安装 safe-rm 工具(转载)
  10. 使用uddi sdk发布服务到UDDI时的安全配置
  11. Python官方开发文档(中文版)
  12. 为什么不能说“接受原假设”?
  13. 顶级域名 一级域名 二级域名 三级域名划分
  14. Vm linux虚拟机与本地宿主机互通
  15. 做马来西亚Lazada的选品技巧是什么
  16. 一加8T 口红电源65W PD快充 充电功率记录
  17. codevs2181 田忌赛马
  18. 【24-业务开发-基础业务-品牌管理-图片管理-阿里云OSS服务开通和使用-阿里云OSS服务API使用-SpringCloudAlibaba OSS服务的使用】
  19. 记用Linux半年小结
  20. 香港举办首个轮椅花车巡游 特首冀提升香港通达程度

热门文章

  1. 计算机控制在线作业一,18秋北理工《计算机控制系统》在线作业-3辅导资料
  2. 计算机联机玩游戏的操作方法,win10系统电脑联机玩罗马复兴的操作方法
  3. Windows 10/WP10预览 Universal App开发的更新内容
  4. 注意!全国九大系列职称都已设专利要求!
  5. 京东云的云原生理念及 Serverless 最佳实践
  6. 最完美打开三星a9 liteusb调试模式的步骤
  7. 服务器安装WIN7 客户端装XP系统,win7系统下怎么安装xp系统
  8. Edge浏览器主页打开是360浏览器主页怎么办?
  9. Caused by: java.security.cert.CertPathValidatorException: timestamp check failed
  10. 网易明日之后服务器瘫痪修复,明日之后:服务器“瘫痪”的原因找到了,原来是北方帝国故意的!...