【鸿蒙软件开发】ArkTS常用组件之Button


前言

Button是按钮组件,通常用于响应用户的点击操作,其类型包括胶囊按钮、圆形按钮、普通按钮。Button当做为容器使用时可以通过添加子组件实现包含文字、图片等元素的按钮。具体用法请参考Button。


一、创建按钮

1.1 Button创建接口介绍

Button通过调用接口来创建,接口调用有以下两种形式:
创建不包含子组件的按钮。

Button(label?: string, options?: { type?: ButtonType, stateEffect?: boolean })

在这里插入图片描述

该接口用于创建不包含子组件的按钮,其中label用来设置按钮文字,type用于设置Button类型,stateEffect属性设置Button是否开启点击效果。

1.2 创建正常的按钮,不包括子组件

我们通过参数1设置上面的字,下一个参数设置type和stateEffect,在他下面使用.属性可以设置其属性

Button('Ok', { type: ButtonType.Normal, stateEffect: true }) 
  .borderRadius(8) 
  .backgroundColor(0x317aff) 
  .width(90)
  .height(40)

在这里插入图片描述

其中:
.borderRadius为设置圆角
.backgroundColor(0x317aff) 为设置背景颜色
.width(90) .height(40) 为设置按钮的大小

在这里插入图片描述

1.3 创建正常的按钮,包括子组件

创建包含子组件的按钮。他没有参数1,即上面的字

Button(options?: {type?: ButtonType, stateEffect?: boolean})

在这里插入图片描述

示例代码如下:

Button({ type: ButtonType.Normal, stateEffect: true }) {
  Row() {
    Image($r('app.media.loading')).width(20).height(40).margin({ left: 12 })
    Text('loading').fontSize(12).fontColor(0xffffff).margin({ left: 5, right: 12 })
  }.alignItems(VerticalAlign.Center)
}.borderRadius(8).backgroundColor(0x317aff).width(90).height(40)

在这里插入图片描述

Row()为布局,即水平布局
Image为创建图片控件
Text为创建字控件

其中.margin({ left: 12 })为外边距左边12
.fontSize(12)为字体大小
.fontColor(0xffffff)为字体颜色

疑问:为什么他们可以连续地这样写.属性.属性
这样其实和.属性 换行 .属性是一样的,不要误解!

.alignItems(VerticalAlign.Center)在后面讲解布局的时候会到来!

1.4 按钮的不同样式

设置按钮类型
Button有三种可选类型,分别为Capsule(胶囊类型)、Circle(圆形按钮)和Normal(普通按钮),通过type进行设置。

我们只需要指定type参数即可改变样式

胶囊按钮(默认类型)

此类型按钮的圆角自动设置为高度的一半,不支持通过borderRadius属性重新设置圆角。

Button('Disable', { type: ButtonType.Capsule, stateEffect: false }) 
  .backgroundColor(0x317aff) 
  .width(90)
  .height(40)

在这里插入图片描述

圆形按钮

此类型按钮为圆形,不支持通过borderRadius属性重新设置圆角。

Button('Circle', { type: ButtonType.Circle, stateEffect: false }) 
  .backgroundColor(0x317aff) 
  .width(90) 
  .height(90)

在这里插入图片描述

普通按钮

此类型的按钮默认圆角为0,支持通过borderRadius属性重新设置圆角。

Button('Ok', { type: ButtonType.Normal, stateEffect: true }) 
  .borderRadius(8) 
  .backgroundColor(0x317aff) 
  .width(90)
  .height(40)

在这里插入图片描述

二、添加事件

2.1 .onClick事件

Button组件通常用于触发某些操作,可以绑定onClick事件来响应点击操作后的自定义行为。

添加事件

只需要像属性一样在后面写.onClick(执行函数)即可

Button('Ok', { type: ButtonType.Normal, stateEffect: true }) 
  .onClick(()=>{ 
    console.info('Button onClick') 
  })

在这里插入图片描述

三、什么时候使用.属性,什么时候用{}

3.1 {}什么时候用

当你需要在这个控件下面添加子类的时候,你需要加{}
例如:
在这里插入图片描述
我们的属性一般在大括号的下面

.属性什么时候用

那么就是与{}相对的了,只要不是子类的范围就可以使用。
比如属性,事件…


总结

本节课主要是讲解了Button的基础使用和Button事件的基础使用,这是非常easy的!!!

ArkTSButton 组件是一个用于 ArkUI 框架中的按钮控件,它可以帮助开发者快速创建和定制各种类型的按钮。通过配置不同的属性,可以轻松地改变按钮的文字、颜色、形状以及交互效果等。 ### 基本使用 ```arkts <template> <div> <!-- 简单文本按钮 --> <ArkTSButton text="点击我" onClick={handleClick}></ArkTSButton> <!-- 图标加文字按钮 --> <ArkTSButton icon="icon.png" text="图标按钮"></ArkTSButton> <!-- 主题色按钮,默认样式为应用的主题配色 --> <ArkTSButton type="primary" text="主题按钮"></ArkTSButton> </div> </template> <script setup lang="ts"> function handleClick() { console.log('按钮被点击了'); } </script> ``` ### 属性说明 - `text` (String): 设置按钮上显示的文本内容。 - `onClick` (Function): 定义当用户点击按钮时触发的动作函数。 - `icon` (String | Object): 可选参数,指定要在按钮左侧展示的图片路径或图标对象。 - `type` (String) : 控制按钮外观风格,支持 `"default"`(默认), `"primary"` 和其他自定义类型. ### 样式与状态变化 你可以进一步利用CSS类名来自定义每个按钮的状态(例如悬停、按下),并且能够调整其尺寸大小及圆角程度: ```css /* 自定义按钮样式 */ .custom-button{ width: auto; height: 40px; /* 高度 */ padding-left: 16px; padding-right: 16px; &:hover { background-color:#eaeaea; //鼠标经过时背景变浅灰 } &[disabled] { opacity:.5; //不可用状态下设置半透明效果 } } // 应用到模板里: <ArkTSButton class="custom-button">自定义样式的按钮</ArkTSButton> ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

人才程序员

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值