HarmonyOS开发:ArkTs常见数据类型

您所在的位置:网站首页 meta分析中常用的数据类型 HarmonyOS开发:ArkTs常见数据类型

HarmonyOS开发:ArkTs常见数据类型

2024-07-10 12:09| 来源: 网络整理| 查看: 265

前言

无论是Android还是iOS开发,都提供了多种数据类型用于常见的业务开发,但在ArkTs中,数据类型就大有不同,比如int,float,double,long统一就是number类型,当然了也不存在char类型,本文针对开发中常用的数据类型,做一个简单的概述,便于第一次接触到ArkTs语言开发的同学,能够快速的对数据类型做一个了解。

ArkTs是TypeScript的超集,其数据类型也是基于TypeScript而来,除了原始5种数据类型之外,还有一种对象类型,再结合ES6中的新类型Symbol和ES10中的新类型BigInt,以及包含常见的枚举、任意类型等等,大概有十多种,但常见常用的就那么几种。

数据类型汇总如下:

数据类型概述number数值boolean布尔string字符串undefined一个未定义或不存在的值null空object对象Symbol独一无二的值bigint任意大的整数enum枚举any任意unknown未知类型void没有任何返回值的类型never永远不存在的类型

在日常的开发中部分会高频次的出现,下面我们就一一的做下分析,由于篇幅有限,会分为两篇文章进行概述;如何判断当前数据是哪一种类型,可以使用typeof关键字来判断,当然了,也并不是所有的类型都可以判断出来。

本文的大纲如下:

1、数值类型number 2、布尔类型boolean 3、字符串类型string 4、对象object 5、未定义或不存在的值undefined 6、空null 7、相关总结

一、数值类型number

记住,凡是表示数值的,不管是二进制还是八进制,还是其他进制,疑惑是长整数,小数,负数等等,只有一个类型表示,那就是number。

局部声明须带关键字

let a: number = 0 //整数 let b: number = -100 //负数 let c: number = 88.88 //小数 let d: number = 0b1010 //二进制 ES6 let e: number = 0o744 //八进制 ES6

成员声明不带关键字

a: number = 0 //整数 b: number = -100 //负数 c: number = 88.88 //小数 d: number = 0b1010 //二进制 e: number = 0o744 //八进制

需要注意的是TypeScript中有类型推断功能,类型可以不写也不会报错,为了避免冗余,日后的书写也建议舍弃类型,标准如下:

局部声明

let a = 0 //整数 let b = -100 //负数 let c = 88.88 //小数 let d = 0b1010 //二进制 let e = 0o744 //八进制

成员声明

a = 0 //整数 b = -100 //负数 c = 88.88 //小数 d = 0b1010 //二进制 e = 0o744 //八进制

当然了以上的前提必须拥有默认值,如果不定义默认值,其类型可携带可不携带,但是为了确定类型,方便之后的代码调用,建议还是带上类型比较好,如下:

局部声明

let a:number let b:number let c:number let d:number let e:number

成员声明

a: number b: number c: number d: number e: number

如果没有声明类型,也不会报错,那么它是一个不确定类型any,后续可以赋值任何类型数据。

二、布尔类型boolean

布尔类型没什么好说的,用于标识true和false。

局部声明

//带默认值 let isBoolean: boolean = false //类型推断后省略类型写法 let isBoolean = false //不带默认值 let isBoolean: boolean

成员声明

//带默认值 isBoolean: boolean = false //类型推断后省略类型写法 isBoolean = false //不带默认值 isBoolean: boolean

其他使用方式跟number类型基本一致。

三、字符串类型string

字符串使用,可单引号也可双引号,都是表示一个字符串。

局部声明

//带默认值 let singleQuotes: string = '单引号字符串' let doubleQuotes: string = "双引号字符串" //类型推断后省略类型写法 let singleQuotes = '单引号字符串' let doubleQuotes = "双引号字符串" //不带默认值 let singleQuotes: string let doubleQuotes: string

成员声明

//带默认值 singleQuotes: string = '单引号字符串' doubleQuotes: string = "双引号字符串" //类型推断后省略类型写法 singleQuotes = '单引号字符串' doubleQuotes = "双引号字符串" //不带默认值 singleQuotes: string doubleQuotes: string

其他使用方式跟number类型基本一致。

四、对象object

在ArkTs中,不管你是一个普通的对象,还是一个数组,元组,集合等等,都是一个对象类型。

let obj = { "name": "AbnerMing" } let test: Test = new Test() let numberArray = [1, 2, 3, 4, 5] let numberArrayObj = new Array() let tuple: [string, number] = ["age", 10] let list = new ArrayList() let map = new HashMap() console.log("当前数据类型1:" + typeof obj) console.log("当前数据类型2:" + typeof test) console.log("当前数据类型3:" + typeof numberArray) console.log("当前数据类型4:" + typeof numberArrayObj) console.log("当前数据类型5:" + typeof tuple) console.log("当前数据类型6:" + typeof list) console.log("当前数据类型7:" + typeof map)

日志打印如下:

1、普通对象

和其他语言的声明及使用方式基本一致,可以对其变量私有,通过get/set方法进行获取,也有私有和公共关键字。

export class Test { private name: string private age: number getName() { return this.name } setName(name: string) { this.name = name } getAge() { return this.age } setAage(age: number) { this.age = age } }

使用方式:

let test = new Test() test.setName("AbnerMing") test.setAage(10) let name = test.getName() let age = test.getAge()

如果没有特别的要求,也可以不用get和set方法:

export class Test { name: string age: number }

使用方式:

let test = new Test() test.name = "AbnerMing" test.age = 10 let name = test.name let age = test.age

除了以上的对象创建和使用之外,在ArkTs中也支持直接花括号的形式声明:

let test = { "name": "AbnerMing", "age": 10 } let name = test.name let age = test.age 2、数组

数组有两种声明方式,一种是使用Array对象,一种直接使用中括号[]。

let array = Array() let arr = [] 默认值 let arr = [1, 2, 3, 4, 5] let array = Array(1, 2, 3, 4, 5)

数组如果没声明类型,它是可以并存多种类型数据的,如下所示:

let arr = [1, "字符串", true, new Test()] let array = Array(1, "字符串", true, new Test())

所以在以后的开发中,对于数组而言,大家尽量精确数据类型,方便后续的使用,针对数组的操作,比如增删改查,后续的文章会有讲解,大家可以持续关注。

3、元组

如果存储的元素数据类型不同,则需要使用元组,元组中允许存储不同类型的元素,元组可以作为参数传递给函数。

let tuple = ["AbnerMing", 10] console.log("key:" + tuple[0]) console.log("value:" + tuple[1])

日志打印:

4、集合

无论是单列集合list,还是双列集合map,都吸取了Java中的优点,基本关于集合操作的方法,在ArkTs中该有的都有,本篇就不过多的介绍了。

五、未定义或不存在的值undefined

当你定义了一个变量而为赋值时,那么它就是undefined。

比如我定义了一个变量,而为进行赋值,如下:

let test console.log(typeof test)

控制台打印如下:

那么在以后的开发中,如果你不确定某个数据是否有值,无论对象还是其他类型,都可以进行undefined判断:

let test if (test != undefined) { console.log("有值") } else { console.log("无值") } 六、空null

null是一个表示"空值"的对象,通常用来表示变量的值为“没有值”,如果需要明确表示一个变量的值为空,就可以使用 null。

let test=null console.log(test)

上述的打印结果为null,和undefined不同的是,需要设置为null,如果不设置就是undefined,需要注意的是,null 和 undefined 在进行比较时,它们的值相等,但数据类型不同。

如下比较:

console.log(null === undefined); // false console.log(null == undefined); // true

除了变量的默认值赋值为null之外, 还可以用来作为函数的返回值,当函数没有需要返回的值时,可以使用 return null,表示函数的返回值为空。

null和undefined进行比较

1、null 表示对象为空,而 undefined 表示缺少值。

2、声明变量但未赋值时,变量的值为 undefined,当需要表示空值时,可以使用 null。

3、在比较时,null 和 undefined 的值相等,但数据类型不同。

九、相关总结

ArkTs是TypeScript的超集,针对数据类型,说强它则强,说不强也不强,比如,一个变量,如未指定数据类型,它可以进行任何类型赋值,以最后一个赋值为最终结果。

let test// any test = 0 test = "字符串" test = true console.log(test)

上述则会打印true,所有在以后的开发中,大家尽量要对数据进行类型限制,既方便与类型区分,也方便错误的甄别,更加有利于代码的健壮。

关于数据类型中的元组、数组、集合,本篇文章只是作为一个简单的了解。

写在最后 如果你觉得这篇内容对你还蛮有帮助,我想邀请你帮我三个小忙:点赞,转发,有你们的 『点赞和评论』,才是我创造的动力。关注小编,同时可以期待后续文章ing🚀,不定期分享原创知识。想要获取更多完整鸿蒙最新VIP学习资源,请移步前往小编:https://qr21.cn/FV7h05



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3