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

简介: 本篇将通过一个简单的计数器应用,带你体验鸿蒙开发环境的实际操作流程。本项目主要练习组件的使用、事件响应和状态管理,帮助开发者熟悉基本的应用构建流程。

本篇将通过一个简单的计数器应用,带你体验鸿蒙开发环境的实际操作流程。本项目主要练习组件的使用、事件响应和状态管理,帮助开发者熟悉基本的应用构建流程。

20241027_142524.gif20241027_142524.gif

关键词
  • 计数器应用
  • 组件操作
  • 事件响应
  • 状态管理
  • HarmonyOS 应用开发

一、创建计数器项目

1.1 在 DevEco Studio 中新建项目
  • 打开 DevEco Studio,选择 File > New > Create Project
  • 选择适合的模板,填写项目名称为 CounterApp,确认创建项目。项目结构文件将在 src/main/ets/pages/Index.ets 文件中生成。
1.2 设计 Index.ets 初始代码

Index.ets 文件中,实现简单的界面设计,包括标题、计数器数字显示和两个按钮(“加”和“减”):

// 入口组件定义,用于指定应用的启动页面
@Entry
@Component
struct Index {
   
  // 定义一个状态变量 count,用 @State 修饰符管理其状态变化
  @State count: number = 0;

  // build() 方法构建页面布局和组件
  build() {
   
    // 使用 Column 组件作为垂直布局容器
    Column() {
   
      // 应用标题文本
      Text('计数器应用')
        .fontSize(24) // 设置标题字体大小为 24
        .fontWeight(FontWeight.Bold) // 设置字体为粗体
        .margin({
    top: 20 }) // 顶部边距为 20
        .alignSelf(ItemAlign.Center) // 水平居中对齐

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

      // 使用 Row 组件实现水平布局,包含“加”和“减”按钮
      Row() {
   
        // "加"按钮,点击后计数值增加
        Button('加') 
          .onClick(() => {
    // 添加点击事件处理函数
            this.count += 1; // 点击时,count 变量加 1
          })
          .fontSize(20) // 设置按钮字体大小为 20
          .width('40%') // 按钮宽度为容器的 40%
          .margin({
    right: 10 }) // 设置右边距为 10

        // "减"按钮,点击后计数值减少
        Button('减') 
          .onClick(() => {
    // 添加点击事件处理函数
            if (this.count > 0) {
    // 限制最小值为 0,避免负数
              this.count -= 1; // 点击时,count 变量减 1
            }
          })
          .fontSize(20) // 设置按钮字体大小为 20
          .width('40%') // 按钮宽度为容器的 40%
          .margin({
    left: 10 }) // 设置左边距为 10
      }
      .justifyContent(FlexAlign.Center) // 水平居中对齐 Row 中的按钮

      // 添加一个“重置”按钮,点击时重置 count 值为 0
      Button('重置') 
        .onClick(() => {
    // 添加点击事件处理函数
          this.count = 0; // 点击时,将 count 变量重置为 0
        })
        .fontSize(20) // 设置按钮字体大小为 20
        .width('100%') // 按钮宽度为容器的 100%
        .margin({
    top: 20 }) // 顶部边距为 20
        .alignSelf(ItemAlign.Center) // 水平居中对齐
    }
    .width('100%') // 设置 Column 容器宽度为 100%
    .height('100%') // 设置 Column 容器高度为 100%
    .padding(20) // 设置内边距为 20
  }
}
1.3 界面说明
  • count 是一个状态变量,显示当前的计数值。
  • 按钮通过 onClick 事件监听点击,分别控制计数器增减。
  • 使用 ColumnRow 组件布局,以保持界面居中和对齐。

二、运行计数器应用

2.1 选择运行设备
  • 在 DevEco Studio 中选择模拟器或连接真实设备。
  • 点击 Run 按钮,应用将在设备上启动,并显示计数器界面。
2.2 操作说明
  • 点击“加”按钮,计数器数值递增。
  • 点击“减”按钮,计数器数值递减。
  • 通过此交互体验,熟悉 @State 状态更新和界面实时刷新效果。

三、增强计数器功能

3.1 添加重置按钮

Row 组件下方,增加一个“重置”按钮,点击时将 count 重置为 0:

Button('重置')
  .onClick(() => {
   
    this.count = 0;
  })
  .fontSize(20)
  .width('100%')
  .margin({
    top: 20 })
  .alignSelf(ItemAlign.Center)
3.2 设置边界条件

count 设置上下限,计数器数值不能小于 0:

Button('减')
  .onClick(() => {
   
    if (this.count > 0) {
   
      this.count -= 1;
    }
  })
  .fontSize(20)
  .width('40%')
  .margin({
    left: 10 })
3.3 添加动态提示

在数值显示下方,增加一个文本提示,显示当前的计数状态:

Text(this.count > 10 ? '计数已达上限' : '')
  .fontSize(16)
  .fontColor(Color.Red)
  .alignSelf(ItemAlign.Center)
  .margin({
    top: 10 })

四、项目结构管理

4.1 创建单独的组件文件

将计数器代码从 Index.ets 文件中提取出来,创建 Counter.ets 文件,以便项目结构清晰,利于维护。

@Component
export struct CounterTest {
   
  @State count: number = 0

  build() {
   
    Column() {
   
      Text('计数器应用')
        .fontSize(24)
        .fontWeight(FontWeight.Bold)
        .margin({
    top: 20 })
        .alignSelf(ItemAlign.Center)

      Text(this.count.toString())
        .fontSize(50)
        .fontWeight(FontWeight.Bold)
        .margin({
    top: 20, bottom: 20 })
        .alignSelf(ItemAlign.Center)

      Text(this.count > 10 ? '计数已达上限' : '')
        .fontSize(16)
        .fontColor(Color.Red)
        .alignSelf(ItemAlign.Center)
        .margin({
    top: 10 })

      Row() {
   
        Button('加')
          .onClick(() => {
    this.count += 1 })
          .fontSize(20)
          .width('40%')
          .margin({
    right: 10 })

        Button('减')
          .onClick(() => {
    if (this.count > 0) this.count -= 1 })
          .fontSize(20)
          .width('40%')
          .margin({
    left: 10 })
      }
      .justifyContent(FlexAlign.Center)

      Button('重置')
        .onClick(() => {
    this.count = 0 })
        .fontSize(20)
        .width('100%')
        .margin({
    top: 20 })
        .alignSelf(ItemAlign.Center)
    }
  }
}
4.2 在 Index.ets 文件中引用 Counter 组件
import {
    CounterTest } from './Counter'

@Entry
@Component
struct Index {
   
  build() {
   
    Column() {
   
      CounterTest()
    }
    .width('100%')
    .height('100%')
    .padding(20)
  }
}
4.3 代码模块化

通过模块化管理,项目结构更清晰,组件之间的耦合度更低,有助于后期维护和功能拓展。


五、常见开发问题与调试

  1. 状态更新不及时:确保使用 @State 修饰变量,避免状态更改后界面不刷新问题。
  2. 事件未响应:检查 onClick 回调函数是否在按钮组件中正确设置,确保事件能被正确触发。
  3. 布局异常:使用 ColumnRow 等布局组件时,注意 alignSelfjustifyContent 的使用,以保证界面元素正确对齐。

小结

本篇通过计数器项目演示了从界面设计、事件响应到状态管理的完整操作流程,帮助开发者熟悉鸿蒙开发的基础技能。通过组件化和模块化管理,项目结构更加清晰、扩展性更强,为后续开发打下了坚实的基础。


下一篇预告

下一篇将介绍鸿蒙UI组件的基础,带你深入了解 Text 和 Button 组件的详细用法。


上一篇: 「Mac畅玩鸿蒙与硬件9」鸿蒙开发环境配置篇9 - 使用 Git 进行版本控制

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


目录
相关文章
|
5天前
|
弹性计算 双11 开发者
阿里云ECS“99套餐”再升级!双11一站式满足全年算力需求
11月1日,阿里云弹性计算ECS双11活动全面开启,在延续火爆的云服务器“99套餐”外,CPU、GPU及容器等算力产品均迎来了全年最低价。同时,阿里云全新推出简捷版控制台ECS Lite及专属宝塔面板,大幅降低企业和开发者使用ECS云服务器门槛。
|
23天前
|
存储 弹性计算 人工智能
阿里云弹性计算_通用计算专场精华概览 | 2024云栖大会回顾
阿里云弹性计算产品线、存储产品线产品负责人Alex Chen(陈起鲲)及团队内多位专家,和中国电子技术标准化研究院云计算标准负责人陈行、北京望石智慧科技有限公司首席架构师王晓满两位嘉宾,一同带来了题为《通用计算新品发布与行业实践》的专场Session。本次专场内容包括阿里云弹性计算全新发布的产品家族、阿里云第 9 代 ECS 企业级实例、CIPU 2.0技术解读、E-HPC+超算融合、倚天云原生算力解析等内容,并发布了国内首个云超算国家标准。
阿里云弹性计算_通用计算专场精华概览 | 2024云栖大会回顾
|
5天前
|
人工智能 弹性计算 文字识别
基于阿里云文档智能和RAG快速构建企业"第二大脑"
在数字化转型的背景下,企业面临海量文档管理的挑战。传统的文档管理方式效率低下,难以满足业务需求。阿里云推出的文档智能(Document Mind)与检索增强生成(RAG)技术,通过自动化解析和智能检索,极大地提升了文档管理的效率和信息利用的价值。本文介绍了如何利用阿里云的解决方案,快速构建企业专属的“第二大脑”,助力企业在竞争中占据优势。
|
3天前
|
人工智能 自然语言处理 安全
创新不设限,灵码赋新能:通义灵码新功能深度评测
自从2023年通义灵码发布以来,这款基于阿里云通义大模型的AI编码助手迅速成为开发者心中的“明星产品”。它不仅为个人开发者提供强大支持,还帮助企业团队提升研发效率,推动软件开发行业的创新发展。本文将深入探讨通义灵码最新版本的三大新功能:@workspace、@terminal 和 #team docs,分享这些功能如何在实际工作中提高效率的具体案例。
|
6天前
|
自然语言处理 数据可视化 前端开发
从数据提取到管理:合合信息的智能文档处理全方位解析【合合信息智能文档处理百宝箱】
合合信息的智能文档处理“百宝箱”涵盖文档解析、向量化模型、测评工具等,解决了复杂文档解析、大模型问答幻觉、文档解析效果评估、知识库搭建、多语言文档翻译等问题。通过可视化解析工具 TextIn ParseX、向量化模型 acge-embedding 和文档解析测评工具 markdown_tester,百宝箱提升了文档处理的效率和精确度,适用于多种文档格式和语言环境,助力企业实现高效的信息管理和业务支持。
3908 0
从数据提取到管理:合合信息的智能文档处理全方位解析【合合信息智能文档处理百宝箱】
|
9天前
|
负载均衡 算法 网络安全
阿里云WoSign SSL证书申请指南_沃通SSL技术文档
阿里云平台WoSign品牌SSL证书是由阿里云合作伙伴沃通CA提供,上线阿里云平台以来,成为阿里云平台热销的国产品牌证书产品,用户在阿里云平台https://www.aliyun.com/product/cas 可直接下单购买WoSign SSL证书,快捷部署到阿里云产品中。
2174 6
阿里云WoSign SSL证书申请指南_沃通SSL技术文档
|
2天前
|
安全 数据建模 网络安全
2024阿里云双11,WoSign SSL证书优惠券使用攻略
2024阿里云“11.11金秋云创季”活动主会场,阿里云用户通过完成个人或企业实名认证,可以领取不同额度的满减优惠券,叠加折扣优惠。用户购买WoSign SSL证书,如何叠加才能更加优惠呢?
825 1
|
21天前
|
编解码 Java 程序员
写代码还有专业的编程显示器?
写代码已经十个年头了, 一直都是习惯直接用一台Mac电脑写代码 偶尔接一个显示器, 但是可能因为公司配的显示器不怎么样, 还要接转接头 搞得桌面杂乱无章,分辨率也低,感觉屏幕还是Mac自带的看着舒服
|
19小时前
|
存储 分布式计算 流计算
实时计算 Flash – 兼容 Flink 的新一代向量化流计算引擎
本文介绍了阿里云开源大数据团队在实时计算领域的最新成果——向量化流计算引擎Flash。文章主要内容包括:Apache Flink 成为业界流计算标准、Flash 核心技术解读、性能测试数据以及在阿里巴巴集团的落地效果。Flash 是一款完全兼容 Apache Flink 的新一代流计算引擎,通过向量化技术和 C++ 实现,大幅提升了性能和成本效益。
326 7
实时计算 Flash – 兼容 Flink 的新一代向量化流计算引擎
|
28天前
|
存储 人工智能 缓存
AI助理直击要害,从繁复中提炼精华——使用CDN加速访问OSS存储的图片
本案例介绍如何利用AI助理快速实现OSS存储的图片接入CDN,以加速图片访问。通过AI助理提炼关键操作步骤,避免在复杂文档中寻找解决方案。主要步骤包括开通CDN、添加加速域名、配置CNAME等。实测显示,接入CDN后图片加载时间显著缩短,验证了加速效果。此方法大幅提高了操作效率,降低了学习成本。
5406 15

热门文章

最新文章