「Mac畅玩鸿蒙与硬件11」鸿蒙 UI 组件篇1 - Text和Button组件详解

简介: 本篇将详细介绍鸿蒙应用开发中的 Text 和 Button 组件。通过本篇内容,你将学习如何使用 Text 组件显示文本、格式化文本样式,以及如何使用 Button 组件处理点击事件并自定义样式。掌握这些基本组件的用法将为后续的 UI 开发奠定基础。

本篇将详细介绍鸿蒙应用开发中的 TextButton 组件。通过本篇内容,你将学习如何使用 Text 组件显示文本、格式化文本样式,以及如何使用 Button 组件处理点击事件并自定义样式。掌握这些基本组件的用法将为后续的 UI 开发奠定基础。

20241027_093327.gif

关键词
  • Text 组件
  • Button 组件
  • 样式设置
  • 事件响应
  • 状态管理

一、Text 组件基础

Text 组件用于显示文本,支持字体大小、颜色、对齐等样式设置,方便开发者根据需求展示不同的文本信息。

1.1 基本用法
  • 直接在 Text 组件中插入字符串或变量来显示文本:

    // 创建一个 Text 组件,显示简单的文本内容
    Text('Hello, HarmonyOS!')
    
    AI 代码解读
1.2 设置文本样式
  • 通过链式调用设置字体大小、粗细和颜色等样式:

    // 设置字体大小、粗细和颜色
    Text('Hello, HarmonyOS!')
      .fontSize(24) // 字体大小为 24
      .fontWeight(FontWeight.Bold) // 加粗显示
      .fontColor(Color.Blue) // 文本颜色为蓝色
    
    AI 代码解读
1.3 文本对齐方式
  • 使用 alignSelf 设置 Text 的对齐方式,例如居中对齐:

    // 设置文本在容器中居中对齐
    Text('Welcome to HarmonyOS')
      .alignSelf(ItemAlign.Center)
      .fontSize(20) // 字体大小为 20
    
    AI 代码解读
1.4 多行显示
  • 使用 maxLines 属性限制最大行数,或通过 textOverflow 设置溢出显示方式:

    // 设置最多显示 2 行,溢出时显示省略号
    Text('这是一个非常长的文本,超过一定行数会显示省略号。')
      .maxLines(2) // 最多显示 2 行
      .textOverflow({
          overflow: TextOverflow.Ellipsis }) // 超出显示省略号
    
    AI 代码解读

运行效果图
Screenshot_2024-10-27T091652.png


二、Button 组件基础

Button 组件用于创建按钮,通常用于捕获用户点击事件。支持自定义样式、圆角和事件响应。

2.1 基本用法
  • Button 组件中直接设置按钮文本:

    // 创建一个按钮,显示 “点击我” 文本
    Button('点击我')
    
    AI 代码解读
2.2 添加点击事件
  • 使用 onClick 函数监听点击事件,并在按钮点击时触发回调函数:

    // 创建一个按钮,点击时执行 onClick 回调
    Button('点击增加计数')
      .onClick(() => {
          // 添加点击事件处理函数
        this.count += 1; // 每次点击时,count 值加 1
      })
    
    AI 代码解读
2.3 按钮样式设置
  • 通过 fontSizefontColor 等设置按钮文本样式:

    // 设置按钮字体大小、颜色和背景颜色
    Button('提交')
      .fontSize(18) // 字体大小为 18
      .fontColor(Color.White) // 字体颜色为白色
      .backgroundColor(Color.Green) // 背景颜色为绿色
    
    AI 代码解读
2.4 设置按钮圆角和边框
  • 使用 borderRadiusborderColor 实现圆角和边框样式:

    // 设置按钮圆角和边框样式
    Button('圆角按钮')
      .borderRadius(10) // 圆角半径为 10
      .borderColor(Color.Gray) // 边框颜色为灰色
      .backgroundColor(Color.Grey) // 背景颜色为灰色
      .fontColor(Color.Black) // 字体颜色为黑色
    
    AI 代码解读

运行效果图
Screenshot_2024-10-27T100729.png


三、Text 与 Button 组件结合实例

在实际开发中,TextButton 组件经常结合使用。下面是一个简单的计数器实例,点击按钮时,Text 显示的计数值更新。

3.1 完整示例代码
@Entry
@Component
struct CounterApp {
   
  @State count: number = 0; // 定义一个状态变量 count,用 @State 修饰管理状态

  build() {
   
    Column() {
   
      // 显示应用标题
      Text('计数器应用')
        .fontSize(24) // 标题字体大小为 24
        .fontWeight(FontWeight.Bold) // 标题字体加粗
        .margin({
    top: 20 }) // 顶部边距为 20
        .alignSelf(ItemAlign.Center) // 水平居中对齐

      // 显示当前计数值
      Text(this.count.toString())
        .fontSize(50) // 字体大小为 50
        .fontWeight(FontWeight.Bold) // 字体加粗
        .margin({
    top: 20, bottom: 20 }) // 上下边距分别为 20
        .alignSelf(ItemAlign.Center) // 水平居中对齐

      // 增加计数的按钮
      Button('增加')
        .onClick(() => {
    // 添加点击事件处理函数
          this.count += 1; // 每次点击,count 值增加 1
        })
        .fontSize(18) // 字体大小为 18
        .fontColor(Color.White) // 按钮字体颜色为白色
        .backgroundColor(Color.Blue) // 按钮背景颜色为蓝色
        .width(100) // 按钮宽度为 100
        .height(50) // 按钮高度为 50
        .alignSelf(ItemAlign.Center) // 水平居中对齐
        .borderRadius(10) // 圆角半径为 10
    }
    .width('100%') // Column 容器宽度为 100%
    .height('100%') // Column 容器高度为 100%
    .padding(20) // 设置内边距为 20
  }
}
AI 代码解读
3.2 说明
  • 该实例使用 @State 修饰的 count 变量保存计数值。
  • 点击按钮时,触发 onClick 事件使 count 值递增。
  • Text 组件实时更新 count 值,实现简单的计数显示。

四、Text 与 Button 组件进阶技巧

4.1 动态样式
  • 使用条件表达式动态改变组件的样式。例如,当计数值为偶数时按钮背景为蓝色,为奇数时为红色:

    // 动态设置按钮颜色,根据 count 是奇数或偶数显示不同颜色
    Button('增加')
      .onClick(() => {
         
        this.count += 1;
      })
      .backgroundColor(this.count % 2 === 0 ? Color.Blue : Color.Red) // 偶数蓝色,奇数红色
    
    AI 代码解读
4.2 多语言支持
  • 使用资源文件实现 Text 内容的多语言适配。在 string.json 文件中定义键值,然后引用:

    • 默认语言src/main/resources/base/element/string.json
    • 中文(中国)src/main/resources/zh_CN/element/string.json
    // string.json
    {
         
        "name": "app_title",
        "value": "计数器应用"
    }
    
    // 使用
    Text($r('app.string.app_title'))
      .fontSize(24)
      .alignSelf(ItemAlign.Center)
    
    AI 代码解读
4.3 按钮点击反馈
  • 使用 backgroundColor 动态变更按钮颜色,或添加 opacity 设置按下反馈效果:

    // 添加按钮点击反馈效果,使用 opacity 动态调整透明度
    Button('提交')
      .onClick(() => {
         
        // 提交事件
        this.count += 1;
        this.isPressed = !this.isPressed; // 改变 isPressed 状态
      })
      .backgroundColor(Color.Green) // 背景颜色为绿色
      .opacity(this.isPressed ? 0.8 : 1) // 按下时透明度变为 0.8
    
    AI 代码解读

小结

本篇介绍了 TextButton 组件的基础用法及其常见样式、事件响应的实现方法。通过学习这些基础组件的用法,开发者可以熟练创建简单的 UI 元素并结合事件实现交互功能,为鸿蒙应用的 UI 开发打下基础。


下一篇预告

下一篇将深入介绍 Image 组件的使用,展示如何在鸿蒙应用中加载和显示图片。


上一篇: 「Mac畅玩鸿蒙与硬件10」鸿蒙开发环境配置篇10 - 项目实战:计数器应用

下一篇: 「Mac畅玩鸿蒙与硬件12」鸿蒙UI组件篇2 - Image组件的使用


作者:SoraLuna
链接:https://www.nutpi.net/thread?topicId=225
來源:坚果派
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


目录
打赏
0
4
4
0
151
分享
相关文章
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
175 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
39 10
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
【04】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-正确安装鸿蒙SDK-结构目录介绍-路由介绍-帧动画(ohos.animator)书写介绍-能够正常使用依赖库等-ArkUI基础组件介绍-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
【04】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-正确安装鸿蒙SDK-结构目录介绍-路由介绍-帧动画(ohos.animator)书写介绍-能够正常使用依赖库等-ArkUI基础组件介绍-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
78 5
【04】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-正确安装鸿蒙SDK-结构目录介绍-路由介绍-帧动画(ohos.animator)书写介绍-能够正常使用依赖库等-ArkUI基础组件介绍-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
Vue Amazing UI 组件库(Vue3+TypeScript+Vite 等最新技术栈开发)
Vue Amazing UI 是一个基于 Vue 3、TypeScript、Vite 等最新技术栈开发构建的现代化组件库,包含丰富的 UI 组件和常用工具函数,并且持续不断维护更新中。另外,组件库全量使用 TypeScript,支持自动按需引入和 Tree Shaking 等,能够显著提升开发效率,降低开发成本。
50 5
Vue Amazing UI 组件库(Vue3+TypeScript+Vite 等最新技术栈开发)
一文轻松拿下HarmonyOS NEXT的自定义组件
本文介绍ArkUI中的自定义组件开发,涵盖基础概念、语法格式、创建与使用方法、成员函数/变量定义及通用样式事件设置等内容。通过实例代码演示,帮助开发者掌握自定义组件的构建与复用技巧,助力高效开发。君志所向,一往无前!希望在成长的路上有你相伴。
38 7
Flame:开源AI设计图转代码模型!生成React组件,精准还原UI+动态交互效果
Flame 是一款开源的多模态 AI 模型,能够将 UI 设计图转换为高质量的现代前端代码,支持 React 等主流框架,具备动态交互、组件化开发等功能,显著提升前端开发效率。
268 1
Harmony os next~UI开发与ArkUI框架
鸿蒙OS的UI开发基于ArkUI框架,采用声明式编程,简化开发流程。五大核心组件(Text、Button、List、Grid、Flex)助力高效布局,支持数据绑定与动态更新。事件响应机制灵敏,适合构建交互丰富的应用。实战技巧包括规范命名、样式复用和调试方法。掌握这些,轻松开发鸿蒙应用。下期预告:分布式开发,记得带上烤冷面!
20 0
|
2月前
|
UED
「Mac畅玩鸿蒙与硬件52」UI互动应用篇29 - 模拟火车票查询系统
本篇教程将实现一个模拟火车票查询系统,通过输入条件筛选车次信息,并展示动态筛选结果,学习事件处理、状态管理和界面展示的综合开发技巧。
85 13
|
2月前
「Mac畅玩鸿蒙与硬件53」UI互动应用篇30 - 打卡提醒小应用
本篇教程将实现一个打卡提醒小应用,通过用户输入时间进行提醒设置,并展示实时提醒状态,实现提醒设置和取消等功能。
75 10
基于Flink CDC 开发,支持Web-UI的实时KingBase 连接器,三大模式无缝切换,效率翻倍!
TIS 是一款基于Web-UI的开源大数据集成工具,通过与人大金仓Kingbase的深度整合,提供高效、灵活的实时数据集成方案。它支持增量数据监听和实时写入,兼容MySQL、PostgreSQL和Oracle模式,无需编写复杂脚本,操作简单直观,特别适合非专业开发人员使用。TIS率先实现了Kingbase CDC连接器的整合,成为业界首个开箱即用的Kingbase CDC数据同步解决方案,助力企业数字化转型。
34 5
基于Flink CDC 开发,支持Web-UI的实时KingBase 连接器,三大模式无缝切换,效率翻倍!

物联网

+关注
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等