【 HarmonyOS 5 入门系列 】鸿蒙HarmonyOS示例项目讲解

【 HarmonyOS 5 入门系列 】鸿蒙HarmonyOS示例项目讲解

一、前言:移动开发声明式 UI 框架的技术变革

在移动操作系统的发展历程中,UI 开发模式经历了从命令式到声明式的重大变革。

根据华为开发者联盟 2024 年数据报告显示,HarmonyOS 设备激活量已突破 7.3 亿台,其中采用 ArkTS 声明式 UI 框架开发的应用占比达 68%,较 2023 年提升 45 个百分点。

这标志着以 ArkTS 为代表的声明式开发范式,正在成为智能终端应用开发的主流选择。

本文将以一个典型的 ArkTS 组件代码为例(代码示例来自IDE示例)。

该代码实现了一个基础的交互界面,包含状态管理、布局设计、事件处理等核心要素,是理解 ArkTS 组件开发的绝佳切入点。

二、ArkTS 组件基础:代码结构与核心装饰器

(1)项目结构梳理
在这里插入图片描述
图(1-1)

如上图所示,该项目整体结构为HarmonyOS示例空Ability项目结构。一个常规的鸿蒙应用项目,重点需要关心编码的部分,分为三个:

  1. AppScope 设置应用的包名,图标等相关信息
  2. entry - src - main - ets 只要编码的所在地。entryAbility作为启动初始的入口,需要修改其中的启动页。pages为UI界面和逻辑开发。
  3. resource 资源目录下的图标目录 media,页面配置路由main_pages

(2)ArkTS组件声明与入口标记



struct Index {// 组件内部逻辑
}

1. @Entry 装饰器:
标记应用的Ability启动加载的入门,我们可以理解为界面。所以该装饰器修饰,都可以在Ability中加载,作为界面使用。

2. 下面为EntryAbility代码示例,配置启动页:

import { AbilityConstant, ConfigurationConstant, UIAbility, Want } from '@kit.AbilityKit';
import { hilog } from '@kit.PerformanceAnalysisKit';
import { window } from '@kit.ArkUI';const DOMAIN = 0x0000;export default class EntryAbility extends UIAbility {onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {this.context.getApplicationContext().setColorMode(ConfigurationConstant.ColorMode.COLOR_MODE_NOT_SET);}onWindowStageCreate(windowStage: window.WindowStage): void {// 舞台添加启动页面windowStage.loadContent('pages/Index', (err) => {if (err.code) {hilog.error(DOMAIN, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err));return;}hilog.info(DOMAIN, 'testTag', 'Succeeded in loading the content.');});}}

3. 下面为路由配置表resource - base - profile - main_pages.json文件:

{"src": ["pages/Index"]
}

当我们使用快捷键,创建空的pages时,IDE会自动在该路由表添加信息。若是手动,一定要记得添加页面的信息。
在这里插入图片描述

4. @Component 装饰器: 代表该类是组建类,可以给其他界面和组件调用,例如:

// 这里引入
import { Index } from './Index'

struct APage {build() {RelativeContainer() {// 这里使用Index()}.height('100%').width('100%')}
}

5. export导出
但是需要注意的是,我们需要对要引入的组件类,进行export导出标记,其他类才能去导出。所以我们的Index类需要作如下修改:



export struct Index {// 组件内部逻辑
}

(3)build函数是做什么的呢?

1. build函数构建概述

组件构建函数,定义UI结构和布局,从示例代码可以看出,build中进行了鱼鳞排版布局的编写。这也是声明式UI布局编写的一大特写,不管是Flutter还是Android的compose,都是如此。

布局通过嵌入-展开的形式,可以一目了然整个UI布局的结构。并且通过链式调用,非常方便的设置UI属性。

 // 应用入口组件标识
 // 声明为组件
export struct Index {// 组件构建函数,定义UI结构和布局build() {// 创建一个相对容器,占满整个父容器空间RelativeContainer() {// 显示message状态变量的文本组件Text(this.message).id('HelloWorld') // 设置组件ID,用于样式或交互引用.fontSize($r('app.float.page_text_font_size')) // 从资源文件获取字体大小.fontWeight(FontWeight.Bold) // 设置字体加粗.alignRules({ // 设置文本在容器中的对齐规则center: { anchor: '__container__', align: VerticalAlign.Center }, // 垂直居中middle: { anchor: '__container__', align: HorizontalAlign.Center } // 水平居中})}.height('100%') // 容器高度占满父容器.width('100%')  // 容器宽度占满父容器}
}

2.RelativeContainer 的定位策略
HarmonyOS 提供 7 种基础布局容器,RelativeContainer(相对布局)适用于元素需相对于容器或其他元素定位的场景。

根据华为 UX 设计规范,在屏幕适配场景中,相对布局的设备兼容性比绝对布局高 40%,尤其适合折叠屏等多形态设备。

.alignRules({center: { anchor: '__container__', align: VerticalAlign.Center },middle: { anchor: '__container__', align: HorizontalAlign.Center }
})

锚点系统:
__container__表示相对于父容器定位,支持自定义锚点(如子组件 ID)。华为布局引擎数据显示,合理使用锚点可减少 20% 的布局计算时间,避免递归定位导致的性能瓶颈。​

对齐策略:
VerticalAlign.Center(垂直居中)与 HorizontalAlign.Center(水平居中)组合使用,实现文本组件的屏幕中心定位。该策略在不同分辨率设备上的定位误差小于 1px(基于 1920x1080 到 4K 分辨率的测试数据)。

(4)数据交互与事件交互
1. 响应式状态管理:@State 装饰器

 message: string = 'Hello World';

@State 修饰的变量会被框架自动追踪,当变量值发生变化时,系统会智能识别受影响的 UI 元素并触发局部重绘。与传统命令式 UI 更新(如 Android 的 findViewById+setText)相比,声明式更新减少了 60% 的 DOM 操作量(基于 Chromium 内核性能测试数据)。

2. 绑定点击事件:
通过在点击事件中,处理message变量的赋值。ArkUI框架自动处理数值变化后,使用了该数值的UI进行重新渲染刷新。

.onClick(() => {this.message = 'Welcome';
})
      // 显示message状态变量的文本组件Text(this.message)

(5)资源文件的管理

.fontSize($r('app.float.page_text_font_size'))

$r () 函数:
从资源文件(resources/base/element/string.json 等)动态获取字体大小,支持多语言、多设备适配。华为开发者平台数据显示,使用资源文件管理样式可使应用包体积减少 15%,避免硬编码导致的维护成本。​

类型安全:
DevEco Studio 提供资源引用智能提示,减少 70% 的资源路径拼写错误(基于千次开发测试数据)。

三、示例项目源码与详细注释

Index.page

 // 应用入口组件标识
 // 声明为组件
export struct Index {// 响应式状态变量,用于存储显示的文本内容 message: string = 'Hello World';// 组件构建函数,定义UI结构和布局build() {// 创建一个相对容器,占满整个父容器空间RelativeContainer() {// 显示message状态变量的文本组件Text(this.message).id('HelloWorld') // 设置组件ID,用于样式或交互引用.fontSize($r('app.float.page_text_font_size')) // 从资源文件获取字体大小.fontWeight(FontWeight.Bold) // 设置字体加粗.alignRules({ // 设置文本在容器中的对齐规则center: { anchor: '__container__', align: VerticalAlign.Center }, // 垂直居中middle: { anchor: '__container__', align: HorizontalAlign.Center } // 水平居中}).onClick(() => { // 点击事件处理this.message = 'Welcome'; // 点击后更新状态变量,触发UI刷新})}.height('100%') // 容器高度占满父容器.width('100%')  // 容器宽度占满父容器}
}

APage.ets

import { Index } from './Index'

struct APage {build() {RelativeContainer() {Index()}.height('100%').width('100%')}
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【SSM】SpringMVC学习笔记7:前后端数据传输协议和异常处理

这篇学习笔记是Spring系列笔记的第7篇,该笔记是笔者在学习黑马程序员SSM框架教程课程期间的笔记,供自己和他人参考。 Spring学习笔记目录 笔记1:【SSM】Spring基础: IoC配置学习笔记-CSDN博客 对应黑马课程P1~P20的内容。 笔记2…

借助 Spring AI 和 LM Studio 为业务系统引入本地 AI 能力

Spring AI 1.0.0-SNAPSHOTLM Studio 0.3.16qwen3-4b 参考 Unable to use spring ai with LMStudio using spring-ai openai module Issue #2441 spring-projects/spring-ai GitHub LM Studio 下载安装 LM Studio下载 qwen3-4b 模型。对于 qwen3 系列模型,测试…

C++学习-入门到精通【13】标准库的容器和迭代器

C学习-入门到精通【13】标准库的容器和迭代器 目录 C学习-入门到精通【13】标准库的容器和迭代器一、标准模板库简介1.容器简介2.STL容器总览3.近容器4.STL容器的通用函数5.首类容器的通用typedef6.对容器元素的要求 二、迭代器简介1.使用istream_iterator输入,使用…

Vue Router的核心实现原理深度解析

1. Vue Router的基本架构 Vue Router的核心功能是实现前端路由,即在不重新加载页面的情况下更改应用的视图。它的基本架构包括: 路由配置:定义路径与组件的映射关系路由实例:管理路由状态和提供导航方法路由视图:渲染…

设计模式——状态设计模式(行为型)

摘要 状态设计模式是一种行为型设计模式,核心在于允许对象在内部状态改变时改变行为。它通过状态对象封装不同行为,使状态切换灵活清晰。该模式包含环境类、抽象状态类和具体状态类等角色,具有避免大量分支判断、符合单一职责和开闭原则等特…

C++ 观察者模式:设计与实现详解

一、引言 在现代软件开发中,组件间的交互与通信是系统设计的核心挑战之一。观察者模式(Observer Pattern)作为一种行为设计模式,提供了一种优雅的解决方案,用于实现对象间的一对多依赖关系。本文将深入探讨 C++ 中观察者模式的设计理念、实现方式及其应用场景。 二、观察…

Windows 账号管理与安全指南

Windows 账号管理与安全指南 概述 Windows 账号管理是系统安全的基础,了解如何正确创建、管理和保护用户账户对于系统管理员和安全专业人员至关重要。本文详细介绍 Windows 系统中的账户管理命令、隐藏账户创建方法以及安全防护措施。 基础账户管理命令 net use…

[蓝桥杯]摆动序列

摆动序列 题目描述 如果一个序列的奇数项都比前一项大&#xff0c;偶数项都比前一项小&#xff0c;则称为一个摆动序列。即 a2i<a2i−1,a2i1 >a2ia2i​<a2i−1​,a2i1​ >a2i​。 小明想知道&#xff0c;长度为 mm&#xff0c;每个数都是 1 到 nn 之间的正整数的…

Python 网络编程 -- WebSocket编程

作者主要是为了用python构建实时网络通信程序。 概念性的东西越简单越好理解,因此,下面我从晚上摘抄的概念 我的理解。 什么是网络通信? 更确切地说&#xff0c;网络通信是两台计算机上的两个进程之间的通信。比如&#xff0c;浏览器进程和新浪服务器上的某个Web服务进程在通…

GM DC Monitor如何实现TCP端口状态监控-操作分享

本节讲解如何通过现有指标提取监控脚本制作自定义的TCP端口监控指标 一、功能介绍 通过提取已有的监控指标的监控命令&#xff0c;来自定义TCP端口的监控指标。 二、配置端口监控 1&#xff09;定位监控脚本 确定脚本及参数如下&#xff1a; check_protocol_tcp.pl --plug…

LabVIEW与Modbus/TCP温湿度监控系统

基于LabVIEW 开发平台与 Modbus/TCP 通信协议&#xff0c;设计一套适用于实验室环境的温湿度数据采集监控系统。通过上位机与高精度温湿度采集设备的远程通信&#xff0c;实现多设备温湿度数据的实时采集、存储、分析及报警功能&#xff0c;解决传统人工采集效率低、环境适应性…

Ntfs!ReadIndexBuffer函数分析之nt!CcGetVirtualAddress函数之nt!CcGetVacbMiss

第一部分&#xff1a; NtfsMapStream( IrpContext, Scb, LlBytesFromIndexBlocks( IndexBlock, Scb->ScbType.Index.IndexBlockByteShift ), Scb->ScbType.Index.BytesPerIndexBuffer, &am…

vite+vue3项目中,单个组件中使用 @use报错

报错信息&#xff1a; [plugin:vite:css] [sass] use rules must be written before any other rules.use 官方说明 注意事项&#xff1a; https://sass-lang.com/documentation/at-rules/use/ 样式表中的 use 规则必须位于所有其他规则&#xff08;除 forward 外&#xff0…

基于VMD-LSTM融合方法的F10.7指数预报

F10.7 Daily Forecast Using LSTM Combined With VMD Method ​​F10.7​​ solar radiation flux is a well-known parameter that is closely linked to ​​solar activity​​, serving as a key index for measuring the level of solar activity. In this study, the ​​…

React 新项目

使用git bash 创建一个新项目 建议一开始就创建TS项目 原因在Webpack中改配置麻烦 编译方法:ts compiler 另一种 bable 最好都配置 $ create-react-app cloundmusic --template typescript 早期react项目 yarn 居多 目前npm包管理居多 目前pnpm不通用 icon 在public文件夹中…

2025年- H65-Lc173--347.前k个高频元素(小根堆,堆顶元素是当前堆元素里面最小的)--Java版

1.题目描述 2.思路 &#xff08;1&#xff09;这里定义了一个小根堆&#xff08;最小堆&#xff09;&#xff0c;根据元素的频率从小到大排序。小根堆原理&#xff1a;堆顶是最小值&#xff0c;每次插入或删除操作会保持堆的有序结构&#xff08;常用二叉堆实现&#xff09;。 …

VR/AR 显示瓶颈将破!铁电液晶技术迎来关键突破

在 VR/AR 设备逐渐走进大众生活的今天&#xff0c;显示效果却始终是制约其发展的一大痛点。纱窗效应、画面拖影、眩晕感…… 传统液晶技术的瓶颈让用户体验大打折扣。不过&#xff0c;随着铁电液晶技术的重大突破&#xff0c;这一局面有望得到彻底改变。 一、传统液晶技术瓶颈…

【bug】Error: /undefinedfilename in (/tmp/ocrmypdf.io.9xfn1e3b/origin.pdf)

在使用ocrmypdf的时候&#xff0c;需要Ghostscript9.55及以上的版本&#xff0c;但是ubuntu自带为9.50 然后使用ocrmypdf报错了 sudo apt update sudo apt install ghostscript gs --version 9.50 #版本不够安装的版本为9.50不够&#xff0c;因此去官网https://ghostscript.c…

【TinyWebServer】线程同步封装

目录 POSIX信号量 int sem_init(sem_t* sem,int pshared,unsingned int value); int sem_destroy(sem_t* sem); int sem_wait(sem_t* sem); int sem_post(sem_t* sem); 互斥量 条件变量 为了对多线程程序实现同步问题&#xff0c;可以用信号量POSIX信号量、互斥量、条件变…

打造高效多模态RAG系统:原理与评测方法详解

引言 随着信息检索与生成式AI的深度融合&#xff0c;检索增强生成&#xff08;RAG, Retrieval-Augmented Generation&#xff09; 已成为AI领域的重要技术方向。传统RAG系统主要依赖文本数据&#xff0c;但真实世界中的信息往往包含图像、表格等多模态内容。多模态RAG&#xf…