HarmonyOS(鸿蒙)应用开发——(一)

目录

1  创建hellopro项目

2  了解ArkTS

3  了解ArkTS的组件

4  组件介绍

4.1 常用基础组件:

4.1.1 Text

4.1.2 Button

4.1.3 TextInput

4.2 容器组件

4.2.1 Column

4.2.2 Row

5  案例——实现一个简易登录页面

5.1 在实现预览效果之前,我们首先要进行分析,如何才能实现上述效果呢?

5.2 创建案例页面文件

6  如何备份这个案例

7  案例——实现头部文件、提交按钮

8  案例——点击数字使其增加


 本篇文章主要介绍在DevEco Studio中创建一个名为hellopro的项目,所以在创建前你的电脑上要安装好DevEco Studio软件,通过几个组件来实现一个简易登录界面,实现头部文件、提交按钮,点击数字使其增加等案例。

1  创建hellopro项目

1. 打开DevEco Studio,点击“Create Project”,进入项目创建页面/模版配置页。

2. 选择项目模版,选择“Application”,然后选择“Empty Ability”,单击“Next”进入工程配置页。

3. 默认项目名称为“MyApplication”。

4. 此处我们可以修改项目名称为“hellopro”,其余默认即可。

Save location可以选择要保存的路径;

Compile SDK是编译的API版本,这里默认选择API9;

Model模型选择Stage。

然后单击“Finish”完成工程创建,等待工程同步完成。

5. 创建完成后进入IDE界面,刚进入时右侧没有显示“Previewer”,等待加载。

6. 右侧出现“Previewer”后可点击显示预览效果。

2  了解ArkTS

ArkTS是HarmonyOS的主要开发语言,了解其之前先了解JavaScript、TypeScript语言。

JavaScript:一种网络高级脚本语言,应用于Web应用开发,可以为网页添加动态功能,实现交互。

TypeScript:JavaScript的一个超集,扩展了JS语法,在JS基础上添加了静态类型定义构建。

ArkTS:兼容TS语言,在TS基础上扩展了声明式UI、状态管理、并发任务,ArkTS是TypeScript的超集。

3  了解ArkTS的组件

如图,是项目进入后默认显示界面。可以看到在“hellopro/entry/src/main/ets/pages”下默认已经创建好了一个名为Index.ets的文件,文件中输入了“Hello World”文本并对其进行了样式的设置。

ArkTS通过@Component和@Entry装饰器,来构成一个自定义组件。通过struct声明组件名。

使用@Entry和@Component装饰的自定义组件作为页面的入口。

使用@Component装饰的自定义组件。

自定义组件使用build方法来进行UI描述。

build方法内可以容纳内置组件和其他自定义组件,如Column和Text都是内置组件。

4  组件介绍

下面列举出本篇文章中所使用的一些组件。

4.1 常用基础组件:

4.1.1 Text

Text组件:用于在界面上展示一段文本信息,可以包含子组件Span。

4.1.2 Button

Button:按钮组件。通常用于响应用户的点击操作,其类型包括胶囊按钮、圆形按钮、普通按钮。

4.1.3 TextInput

TextInput:单行文本输入框组件。

4.2 容器组件

首先了解什么是布局容器:

ArkTS中提供了Column和Row容器来实现线性布局。线性布局容器表示按照垂直方向或者水平方向排列子组件的容器。

4.2.1 Column

Column:表示沿垂直方向布局的容器,可以包含子组件。

4.2.2 Row

Row:表示沿水平方向布局的容器,可以包含子组件。

5  案例——实现一个简易登录页面

实现一个简易登录页面,预览效果如图。

5.1 在实现预览效果之前,我们首先要进行分析,如何才能实现上述效果呢?

可以看出图中有“手机号”、“验证码”两组文本,那么就要用到Text组件来实现;

文本后面是文本输入框,用TextInput单行文本输入框组件。

下面有“重置”、“登录”两个按钮,则用到Button按钮组件;两个按钮背景颜色不同可以使用.backgroundColor来设置。

5.2 创建案例页面文件

我们可以新建一个ArkTS文件来编辑代码实现页面效果。如图,在“hellopro/entry/src/main/ets/pages”文件夹下选中pages并右击,点击New>ArkTS File。

为ArkTS文件取名为“Login”。

创建完成后,在Login.ets文件里面没有代码内容。

在Login.ets中编辑如下代码并保存,完成好后点击“Previewer”预览。

@Entry                     // 装饰器,代表的是这个页面入口地方@Component                 // 装饰器struct Login {             // 自定义组件build() {                // build函数,用于构建页面UI//鸿蒙提供很多内置UI组件可以直接使用,内置组件字母大写Column() {Row() {Text('手机号')TextInput()}Row() {Text('验证码')TextInput()}Row() {Button('重置').backgroundColor('#cccccc')Button('登录')}}}}

预览效果如图,简易登录页面成功实现。

6  如何备份这个案例

当我们成功实现这个案例后,后续还会创建并实现其他页面效果,将这些文件放在同一文件夹中可能会感到杂乱,这时我们就要对当前实现的效果进行复制备份。

1. 选中main文件夹后右击并点击Copy,或者选中main文件夹后按键盘Ctrl+C组合键进行复制。

2. 复制好后选中src文件夹右击并点击Paste,或者选中src文件夹后按键盘Ctrl+V组合键进行粘贴。

3. 点击后弹出提示框,在New name中我们可以修改文件名,To directory默认即可,修改完成后点击OK。

4. 如图,可以看到我们备份的名为“01-登录”的文件,里面同样有Login.ets文件,后续还想备份其他案例效果可使用此步骤完成。

7  案例——实现头部文件、提交按钮

在ets文件夹下创建名为“components”的文件夹,里面保存预览文本文件并导出。

在pages文件夹原有文件Index.ets中编写代码导入“components”文件夹中的文本文件,最终要实现的预览结果如下图:

1. 选中ets文件夹鼠标右击,选择New>Directory创建目录。

2. 为目录取名为“components”并按回车键完成。

3. 创建成功。

4. 在创建好的components文件夹下创建两个后缀.ets的文件分别取名为“Header.ets”、“Footer.ets”。

选择components文件夹鼠标右击,选择New>ArkTS File。

为文件命名为“Header”后按回车键。

成功创建Header.ets文件,里面需要编辑代码。

按照上述方法在components文件夹中创建Footer.ets文件。

5. 文件创建完成后,在两个文件中编写代码。首先,在Header.ets文件中输入如下内容并保存:

@Component
export struct Header {build() {Row() {Text('头部文件')}}
}

6. 在Footer.ets文件中输入如下内容并保存:

@Component
export struct Footer {build() {Column() {Row() {Button('提交按钮')}}}
}

7. 在ets/pages文件夹下的Index.ets文件中输入如下内容并保存:

import { Footer } from '../components/Footer'
import { Header } from '../components/Header'
@Entry
@Component
struct Index {build() {Column() {Header()Footer()}}
}

8. 完成上述后点击右侧Previewer预览,如图完成案例中的效果。

8  案例——点击数字使其增加

要实现的预览结果:

点击蓝色“++”按钮实现数字增加。

1. 在main/ets/pages文件夹中新创建一个名为“Dianji”的ArkTS文件用来存放代码,创建方法参考上述步骤中的方法。

2. 创建完成。

3. 在Dianji.ets文件中输入如下内容:

@Entry
@Component
struct Dianji {@State count: number = 2024build() {Column() {Text(this.count.toString())Button('++').onClick(()=>{this.count ++console.log(this.count.toString())})}}
}

4. 点击右侧Previewer预览效果。

5. 点击“++”按钮可以实现数字增加,完成案例要求。

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

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

相关文章

MCU技术的创新浪潮与产业变革

MCU技术的创新浪潮与产业变革 一、MCU技术的创新发展 MCU,即微控制器,作为现代电子设备的核心部件,一直在不断地创新与发展。随着科技的进步,MCU的性能得到了极大的提升,功能也越来越丰富。从8位到32位,再…

【SpringMVC】知识汇总

SpringMVC 短暂回来,有时间就会更新博客 文章目录 SpringMVC前言一、第一章 SpingMVC概述二、SpringMVC常用注解1. Controller注解2. RequestMapping注解3. ResponseBody注解4. RequestParam5. EnableWebMvc注解介绍6. RequestBody注解介绍7. RequestBody与RequestP…

echart多折线图堆叠 y轴和实际数据不对应

当使用 ECharts 绘制堆叠折线图时,有时会遇到 y 轴与实际数据不对应的问题。 比如明明值是50,但折线点在y轴的对应点却飙升到了二百多 解决办法: 查看了前端代码发现在echart的图表中有一个‘stack’的属性,尝试把他删除之后y轴的…

探索vLLM:释放超大规模语言模型的力量

背景 vLLM是伯克利大学LMSYS组织开源的大语言模型高速推理框架,旨在极大地提升实时场景下的语言模型服务的吞吐与内存使用效率。vLLM是一个快速且易于使用的库,用于 LLM 推理和服务,可以和HuggingFace 无缝集成。vLLM利用了全新的注意力算法「PagedAttention」,有效地管理注…

分布式游戏服务器

1、概念介绍 分布式游戏服务器是一种专门为在线游戏设计的大型系统架构。这种架构通过将游戏服务器分散部署到多台计算机(节点)上,实现了数据的分散存储和计算任务的并行处理。每个节点都负责处理一部分游戏逻辑和玩家请求,通过高…

应急响应靶机训练-Web3题解

前言 接上文,应急响应靶机训练-Web3。 前来挑战!应急响应靶机训练-Web3 题解 首先登录用户administrator 寻找隐藏用户 找到隐藏用户hack6618$ 然后去找apache的日志文件 分析得出两个IP地址 192.168.75.129 192.168.75.130 然后更换hack6618$的…

Offline RL : SEABO: A Simple Search-Based Method for Offline Imitation Learning

NIPS 2024 paper Intro 离线强化学习一般需要带奖励标签的数据,而现实中这种标签获取困难。本文提出一种基于搜索的离线方法SEABO。SEABO以无监督学习的方式,对最接近专家演示的transaction较大的奖励,否则分配较小的奖励。 Method SEAB…

Flume-transaction机制源码分析

一、整体流程 FileChannel主要是由WAL预写日志和内存队列FlumeEventQueue组成。 二、Transaction public interface Transaction {// 描述transaction状态enum TransactionState { Started, Committed, RolledBack, Closed }void begin();void commit();void rollback();voi…

Introduction to Data Mining 数据挖掘

Why Data Mining? • The Explosive Growth of Data: from terabytes to petabytes — Data collection and data availability ◦ Automated data collection tools, database systems, Web, computerized society — Major sources of abundant data ◦ Business: Web, e-co…

哔哩哔哩秋招Java二面

前言 作者:晓宜 个人简介:互联网大厂Java准入职,阿里云专家博主,csdn后端优质创作者,算法爱好者 一面过后面试官叫我别走,然后就直接二面,二面比较简短,记录一下,希望可以…

JWT 认证机制

1. 了解 Session 认证的局限性 Session 认证机制需要配合 Cookie 才能实现。由于 Cookie 默认不支持跨域访问,所以当涉及到前端跨域请求后端接口的时候,需要做很多额外的配置,才能实现跨域 Session 认证 注意: 1. 当前端请求后端接…

AMPQ和rabbitMQ

RabbitMQ 的 Channel、Connection、Queue 和 Exchange 都是按照 AMQP(Advanced Message Queuing Protocol)标准实现的。 AMPQ的网络部分 AMQP没有使用HTTP,使用TCP自己实现了应用层协议。 AMQP实现了自己特有的网络帧格式。 一个Connection…

用 Visual Studio 调试器中查看内存中图像

返回目录:OpenCV系列文章目录(持续更新中......) 前一篇:OpenCV4.9.0在windows系统下的安装 后一篇:OpenCV-Java 开发简介 ​警告 本教程可以包含过时的信息。 Image Watch 是 Microsoft Visual Studio 的插件&a…

气膜馆建造成本高吗?专业气膜厂家告诉你!

气膜馆作为一种现代化建筑结构,在体育、娱乐和展览领域备受青睐。然而,对于许多人来说,最关心的问题之一就是建造气膜馆的成本。下面轻空间气膜厂家将带您深入探讨气膜馆的建设成本,特别关注每平米的建设成本是多少,以…

matlab 将矩阵写入文件

目录 一、概述1、算法概述2、主要函数二、将矩阵写入到文本文件三、将矩阵写入电子表格文件四、将矩阵写入指定的工作表和范围五、将数据追加到电子表格六、将矩阵数据追加到文本文件七、参考链接本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此…

Android 系统源码快速入门

Android源码快速入门 今天分享的内容是Android源码快速入门,主要分为以下几个步骤: * 硬件要求 * 虚拟机安装 * 开发环境搭建 * 下载编译源码 * 从一个简单的实际开发需求体验 Framework 开发硬件要求 用于 Android Framework 开发的电脑需要较强的 C…

HBase在表操作--显示中文

启动HBase后,Master和RegionServer两个服务器,分别对应进程为HMaster和HRegionServe。(可通过jps查看) 1.进入表操作 hbase shell 2.查看当前库中存在的表 list 3.查看表中数据(注:学习期间可用&#…

传统企业在推行TPM时需要注意哪些问题?

当下,传统企业面临着转型升级的巨大压力。为了提升生产效率和产品质量,许多企业选择推行全面生产维护(Total Productive Maintenance,简称TPM)管理模式。然而,在实际推行过程中,传统企业需要注意…

MAC IntelliJ IDEA搭建Doris Fe

目录 版本信息 安装环境依赖 拉取源码 下载 Doris 编译依赖 修改系统最大文件句柄数 编译 Doris 配置 Debug 环境 生成 FE 代码 FE模块代码导入 配置 Debug FE 启动 FE 报错问题 版本信息 本次安装的doris版本信息为doris-2.1.0-rc11 IntelliJ IDEA 配置jdk17、m…

CCF202309-2——坐标变换(其二)80分代码及思路

思路,还是暴力求解,直接对每一个操作进行遍历,最后结果保留三位小数,但是不知道为什么直接printf("%.3f",x)进行输出没有分,结果完全对得上,以下是80分提交代码,可能大的测试点没有通…