小学姐教你HarmonyOS开发-02-ArkTS语言基础

2024-06-12 18:52

本文主要是介绍小学姐教你HarmonyOS开发-02-ArkTS语言基础,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简单介绍基于TypeScript扩展的ArkTS语言。
ArkTS是鸿蒙生态的应用开发语言,由ArkUI框架提供,以声明式开发范式来开发界面,让开发者可以更简洁、更自然的方式开发高性能应用。

源课程:d2school(第2学堂)

什么是ArkTS?

ArkTS是鸿蒙生态的应用开发语言。它在保持TypeScript(简称TS)基本语法风格的基础上,对TS的动态类型特性施加更严格的约束,引入静态类型。同时,提供了声明式UI、状态管理等相应的能力,让开发者可以更简洁、更自然的方式开发高性能应用。

ArkTS、TS和JS的关系

TypeScript(简称TS)是JavaScript(简称JS)的超集,ArkTS则是TS的超集。

关系图

初步了解TS常用的基础类型

已经了解的同学可跳过

  • 布尔值:TS中可以使用 boolean 来表示这个变量是布尔值,可以赋值为true或者false。
let show: boolean = false; 
  • 数字:TS中的所有数字都是浮点数,这些浮点数的类型是 number
let num1: number = 2024; 
let num2: number = 0b11111101000; // 二进制 2024 
let num3: number = 0o3750; // 八进制 2024 
let num4: number = 0x7e8; // 十六进制 2024 
  • 字符串:TS里使用 string 表示文本数据类型,可以使用双引号或单引号表示字符串。
let name: string = "Jacky"; name = 'Mick'; 
  • 数组:TS有两种方式可以定义数组。

第一种,可以在元素类型后面接上 [],表示由此类型元素组成的一个数组。

let list: number[] = [1, 2, 3]; 
第二种方式是使用数组泛型,Array<元素类型>。
let list: Array<number> = [1, 2, 3]; 
  • 元祖:元组类型允许表示一个已知元素数量和类型的数组,各元素的类型不必相同。 比如,你可以定义一对值分别为 stringnumber 类型的元组。
let x: [string, number]; x = ['hello', 10]; // OK 
x = [10, 'hello']; // Error 
  • Unknown:标记暂时未知类型的变量,直接通过编译阶段的检查。
let value: unknown = 4;
value= 'maybe a string instead';
value= false; 
  • Void:当一个函数没有返回值时,你通常会见到其返回值类型是 void
function test(): void { console.log('1'); } 
  • 联合类型:表示取值可以为多种类型中的一种。
let value: string | number;value= 'hello'; value= 1; 
  • 为函数定义类型

为了确保输入输出的准确性,我们可以函数添加类型。
实现可选参数的功能只需在参数名旁使用 ?

function add(x: number, y: number, z?: number): number { return x + y; 
} 

ArkTS声明式开发范式

装饰器

用来装饰类、结构体、方法以及变量,赋予其特殊的含义。

  • @Entry:表示这是个入口组件
  • @Component:表示这是个自定义组件;
  • @State:表示组件中的状态变量,此状态变化会引起UI变更。

自定义组件

可复用的UI单元,可组合其它组件,如上图中被 @Component 装饰的 struct Hello

UI描述

声明式的方式来描述 UI 的结构,如上图中 build() 方法内部的代码块。

内置组件

框架中默认内置的基础和布局组件,可直接被开发者调用,比如上图中的 RowColumnText

属性方法

用于组件属性的配置,统一通过属性方法进行设置,如上图中的 fontSize()fontWeight()width()height() 等,可通过链式调用的方式设置多项属性。

事件方法

用于添加组件对事件的响应逻辑,统一通过事件方法进行设置,如上图中跟随在 Text 后面的 onClick()

ArkTS基础知识

渲染控制语法🎞️ (本小节带视频)

  • 条件渲染:ifelse ifelse
@Entry
@Component
struct Index {@State count: number = 2build() {Row() {Column() {Button(`count:${this.count}`).fontSize('30').onClick(() => {this.count--})if (this.count === 0) {Text('Hello').fontSize(50)} else if (this.count === 1) {Text('Hello World').fontSize(50)} else {Text('Hello ArkTs').fontSize(50)}}.width('100%')}.height('100%')}
}
  • 效果-1

HMOS-ls02-1-ArkTS语言基础-1

  • 循环渲染:ForEach

@Entry
@Component
struct list {@State listData: Array<string> = ['苹果', '西瓜', '草莓']build() {Row() {Column() {ForEach(this.listData,(item: string, index: number) => {Text(`${index + 1}、${item}`).fontSize(40)},(item: string) => item //可选)}.width('100%')}.height('100%')}
}
  • 效果-2

HMOS-ls02-1-ArkTS语言

这篇关于小学姐教你HarmonyOS开发-02-ArkTS语言基础的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1055048

相关文章

Java利用Spire.Doc for Java实现在模板的基础上创建Word文档

《Java利用Spire.DocforJava实现在模板的基础上创建Word文档》在日常开发中,我们经常需要根据特定数据动态生成Word文档,本文将深入探讨如何利用强大的Java库Spire.Do... 目录1. Spire.Doc for Java 库介绍与安装特点与优势Maven 依赖配置2. 通过替换

C语言逗号运算符和逗号表达式的使用小结

《C语言逗号运算符和逗号表达式的使用小结》本文详细介绍了C语言中的逗号运算符和逗号表达式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习... 在C语言中逗号“,”也是一种运算符,称为逗号运算符。 其功能是把两个表达式连接其一般形式为:表达

Go语言实现桥接模式

《Go语言实现桥接模式》桥接模式是一种结构型设计模式,它将抽象部分与实现部分分离,使它们可以独立地变化,本文就来介绍一下了Go语言实现桥接模式,感兴趣的可以了解一下... 目录简介核心概念为什么使用桥接模式?应用场景案例分析步骤一:定义实现接口步骤二:创建具体实现类步骤三:定义抽象类步骤四:创建扩展抽象类步

GO语言实现串口简单通讯

《GO语言实现串口简单通讯》本文分享了使用Go语言进行串口通讯的实践过程,详细介绍了串口配置、数据发送与接收的代码实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录背景串口通讯代码代码块分解解析完整代码运行结果背景最近再学习 go 语言,在某宝用5块钱买了个

精准寻车+鸿蒙有礼特别版均已上线! 华为鸿蒙HarmonyOS 6负一屏新升级

《精准寻车+鸿蒙有礼特别版均已上线!华为鸿蒙HarmonyOS6负一屏新升级》不少朋友升级华为鸿蒙HarmonyOS6后,发现华为负一屏此次也新增了精准寻车功能,还为过往鸿蒙5.1及以上用户再度... 最近科技圈热议话题当属华为全新发布的Mate 80系列,这次不仅有全金属机身,第二代红枫影像和全新麒麟新品

Python+wxPython开发一个文件属性比对工具

《Python+wxPython开发一个文件属性比对工具》在日常的文件管理工作中,我们经常会遇到同一个文件存在多个版本,或者需要验证备份文件与源文件是否一致,下面我们就来看看如何使用wxPython模... 目录引言项目背景与需求应用场景核心需求运行结果技术选型程序设计界面布局核心功能模块关键代码解析文件大

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js

JavaScript装饰器从基础到实战教程

《JavaScript装饰器从基础到实战教程》装饰器是js中一种声明式语法特性,用于在不修改原始代码的情况下,动态扩展类、方法、属性或参数的行为,本文将从基础概念入手,逐步讲解装饰器的类型、用法、进阶... 目录一、装饰器基础概念1.1 什么是装饰器?1.2 装饰器的语法1.3 装饰器的执行时机二、装饰器的

Java JAR 启动内存参数配置指南(从基础设置到性能优化)

《JavaJAR启动内存参数配置指南(从基础设置到性能优化)》在启动Java可执行JAR文件时,合理配置JVM内存参数是保障应用稳定性和性能的关键,本文将系统讲解如何通过命令行参数、环境变量等方式... 目录一、核心内存参数详解1.1 堆内存配置1.2 元空间配置(MetASPace)1.3 线程栈配置1.

GO语言zap日志库理解和使用方法示例

《GO语言zap日志库理解和使用方法示例》Zap是一个高性能、结构化日志库,专为Go语言设计,它由Uber开源,并且在Go社区中非常受欢迎,:本文主要介绍GO语言zap日志库理解和使用方法的相关资... 目录1. zap日志库介绍2.安装zap库3.配置日志记录器3.1 Logger3.2 Sugared