当前位置: 首页 > news >正文

HarmonyOS NEXT 开发之ArkTS基础入门

ArkTS 是 HarmonyOS NEXT 的开发语言,它基于 TypeScript 并进行了扩展和优化。以下是一些基础语法知识点、示例用法及注意事项。

一、ArkTS 简介

ArkTS 是一种基于 TypeScript 的编程语言,主要用于 HarmonyOS 应用的 UI 界面和业务逻辑开发。它在 TypeScript 的基础上,进行了一些针对 HarmonyOS 系统的优化和定制。

二、创建 ArkTS 项目

  1. 打开 DevEco Studio:点击 File -> New -> Project,选择适合的模板作为项目类型。
  2. 输入项目名称和包名:然后点击 Next。
  3. 完成项目创建:点击 Finish,DevEco Studio 将自动创建一个 ArkTS 项目。

三、编写 ArkTS 代码

  1. 编写 UI 界面:ArkTS 项目的 UI 界面使用 XML 文件定义,可以在 resources/base/layout 目录下找到应用的布局文件。
  2. 编写业务逻辑:ArkTS 项目的业务逻辑代码使用 TypeScript 编写,可以在 src/main/js/default 目录下找到应用的 TypeScript 代码。
  3. 添加资源文件:ArkTS 项目的图片、字符串等资源文件存放在 resources/base 目录下。
  4. 配置文件:ArkTS 项目的配置信息存放在 config.json 文件中。

四、ArkTS 关键语法和使用示例

1. 类型注解

类型注解是 TypeScript 的核心特性之一,它允许在变量、函数参数和函数返回值上添加类型信息。

let message: string = "Hello, HarmonyOS";
let count: number = 10;
function greet(name: string): string {return `Hello, ${name}`;
}
let greeting: string = greet("HarmonyOS");
2. 接口

接口是 TypeScript 中定义复杂类型的一种方式,它可以描述一个对象的结构。

interface Person {name: string;age: number;
}
function showPersonInfo(person: Person) {console.log(`Name: ${person.name}, Age: ${person.age}`);
}
let person: Person = { name: "John", age: 30 };
showPersonInfo(person);
3. 类

类是 TypeScript 中定义对象类型的一种方式,支持继承和多态。

class Animal {constructor(public name: string) {}speak() {console.log(`${this.name} makes a noise.`);}
}class Dog extends Animal {speak() {console.log(`${this.name} barks.`);}
}let dog = new Dog("Bingo");
dog.speak(); // Bingo barks.
4. 继承

继承允许一个类(子类)继承另一个类(父类)的属性和方法。

class Base {commonMethod() {console.log("Common Method");}
}class Derived extends Base {derivedMethod() {console.log("Derived Method");}
}let derived = new Derived();
derived.commonMethod(); // Common Method
derived.derivedMethod(); // Derived Method
5. 泛型

泛型允许在定义函数、接口或类时使用类型参数。

function identity<T>(arg: T): T {return arg;
}let output = identity<string>("Hello, world!");
console.log(output); // "Hello, world!"
6. 模块

模块是 TypeScript 中组织代码的一种方式,支持导入和导出。

// file1.ts
export function sayHello(name: string) {console.log(`Hello, ${name}`);
}// file2.ts
import { sayHello } from "./file1";
sayHello("TypeScript");
7. 装饰器

装饰器是一种特殊类型的声明,它可以被附加到类、方法、属性或参数上。

function log(target: any, propertyKey: string, descriptor: PropertyDescriptor) {console.log(`Property ${propertyKey} is being called`);
}class Person {@logname() {return "John";}
}let person = new Person();
person.name(); // Property name is being called
8. 异步编程

异步编程允许你编写非阻塞的代码。

async function fetchData() {return await fetch("https://api.example.com/data");
}fetchData().then(data => console.log(data));
9. 类型别名

类型别名允许你为类型定义一个新名称。

type Name = string;
type Coordinates = { x: number; y: number };let name: Name = "Alice";
let coordinates: Coordinates = { x: 10, y: 20 };
10. 类型保护

类型保护是一种检查变量类型的方法,可以在编译时确保变量具有正确的类型。

type Shape = Circle | Square;
function getArea(shape: Shape): number {if (shape instanceof Circle) {return Math.PI * shape.radius ** 2;} else {return shape.width * shape.height;}
}
11. 枚举

枚举是一种特殊的类型,它允许你为一组有限的值定义友好的名字。

enum Direction {Up,Down,Left,Right,
}function move(direction: Direction): void {console.log(`Moving in direction: ${Direction[direction]}`);
}
move(Direction.Up);
12. 映射类型

映射类型允许你根据现有类型创建新的类型。

type ReadonlyPoint = Readonly<Point>;
let readonlyPoint: ReadonlyPoint = { x: 10, y: 20 };
readonlyPoint.x = 30; // Error: Cannot assign to 'x' because it is a read-only property

五、注意事项

  1. 类型检查:ArkTS 在编译时进行类型检查,可以在代码运行前发现和修复错误。
  2. IDE 支持:由于有了类型信息,IDE 可以提供更好的自动完成、导航和重构功能。
  3. 模块化编程:ArkTS 支持模块化编程,可以将代码组织成模块,以便于管理和维护。

通过以上示例和注意事项,你可以更好地理解和掌握 ArkTS 的基础语法和使用方式。

http://www.lryc.cn/news/408200.html

相关文章:

  • UE5 C++跑酷练习(Part2)
  • 从0开始搭建vue + flask 旅游景点数据分析系统(二):搭建基础框架
  • 【过滤器 vs 拦截器】SpringBoot中过滤器与拦截器:明智选择的艺术(如何在项目中做出明智选择)
  • 2024-06学习笔记
  • 【VUE】封装一个追随鼠标的漂浮组件框架
  • mapstruct与lombok结合使用
  • 【SpringBoot】Web开发之URL映射
  • 对递归的一些理解。力扣206题:翻转链表
  • Kafka面试三道题
  • C/C++编程-算法学习-数字滤波器
  • maven介绍 搭建Nexus3(maven私服搭建)
  • 电商项目之如何判断线程池是否执行完所有任务
  • 【前端 15】Vue生命周期
  • PCIe总线-Linux内核PCIe软件框架分析(十一)
  • 视觉SLAM第二讲
  • mysql1055报错解决方法
  • Java的@DateTimeFormat注解与@JsonFormat注解的使用对比
  • 德国云手机:企业移动办公解决方案
  • 【React】useState:状态管理的基石
  • 商品中心关于缓存热key的解决方案
  • 【Python系列】Parquet 数据处理与合并:高效数据操作实践
  • 大脑自组织神经网络通俗讲解
  • org.springframework.context.annotation.DeferredImportSelector如何使用?
  • 缓慢变化维
  • Vue常用的指令都有哪些?都有什么作用?什么是自定义指令?
  • kettle从入门到精通 第八十一课 ETL之kettle kettle中的json对象字段写入postgresql中的json字段正确姿势
  • 计算机网络实验-RIP配置与分析
  • 33.【C语言】实践扫雷游戏
  • git学习笔记(总结了常见命令与学习中遇到的问题和解决方法)
  • 【计算机网络】TCP协议详解