当前位置:   article > 正文

HarmonyOS开发:ArkTs常见数据类型(一)_鸿蒙开发中如何去定义对象,数组类型的数据

鸿蒙开发中如何去定义对象,数组类型的数据

前言

无论是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。

局部声明须带关键字

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

成员声明不带关键字

  1. a: number = 0 //整数
  2. b: number = -100 //负数
  3. c: number = 88.88 //小数
  4. d: number = 0b1010 //二进制
  5. e: number = 0o744 //八进制

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

局部声明

  1. let a = 0 //整数
  2. let b = -100 //负数
  3. let c = 88.88 //小数
  4. let d = 0b1010 //二进制
  5. let e = 0o744 //八进制

成员声明

  1. a = 0 //整数
  2. b = -100 //负数
  3. c = 88.88 //小数
  4. d = 0b1010 //二进制
  5. e = 0o744 //八进制

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

局部声明

  1. let a:number
  2. let b:number
  3. let c:number
  4. let d:number
  5. let e:number

成员声明

  1. a: number
  2. b: number
  3. c: number
  4. d: number
  5. e: number

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

二、布尔类型boolean

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

局部声明

  1. //带默认值
  2. let isBoolean: boolean = false
  3. //类型推断后省略类型写法
  4. let isBoolean = false
  5. //不带默认值
  6. let isBoolean: boolean

成员声明

  1. //带默认值
  2. isBoolean: boolean = false
  3. //类型推断后省略类型写法
  4. isBoolean = false
  5. //不带默认值
  6. isBoolean: boolean

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

三、字符串类型string 

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

局部声明

  1. //带默认值
  2. let singleQuotes: string = '单引号字符串'
  3. let doubleQuotes: string = "双引号字符串"
  4. //类型推断后省略类型写法
  5. let singleQuotes = '单引号字符串'
  6. let doubleQuotes = "双引号字符串"
  7. //不带默认值
  8. let singleQuotes: string
  9. let doubleQuotes: string

成员声明

  1. //带默认值
  2. singleQuotes: string = '单引号字符串'
  3. doubleQuotes: string = "双引号字符串"
  4. //类型推断后省略类型写法
  5. singleQuotes = '单引号字符串'
  6. doubleQuotes = "双引号字符串"
  7. //不带默认值
  8. singleQuotes: string
  9. doubleQuotes: string

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

四、对象object

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

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

日志打印如下:

1、普通对象

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

  1. export class Test {
  2. private name: string
  3. private age: number
  4. getName() {
  5. return this.name
  6. }
  7. setName(name: string) {
  8. this.name = name
  9. }
  10. getAge() {
  11. return this.age
  12. }
  13. setAage(age: number) {
  14. this.age = age
  15. }
  16. }

使用方式:

  1. let test = new Test()
  2. test.setName("AbnerMing")
  3. test.setAage(10)
  4. let name = test.getName()
  5. let age = test.getAge()

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

  1. export class Test {
  2. name: string
  3. age: number
  4. }

使用方式:

  1. let test = new Test()
  2. test.name = "AbnerMing"
  3. test.age = 10
  4. let name = test.name
  5. let age = test.age

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

  1. let test = { "name": "AbnerMing", "age": 10 }
  2. let name = test.name
  3. let age = test.age

2、数组

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

  1. let array = Array<number>()
  2. let arr = []

默认值

  1. let arr = [1, 2, 3, 4, 5]
  2. let array = Array<number>(1, 2, 3, 4, 5)

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

  1. let arr = [1, "字符串", true, new Test()]
  2. let array = Array<any>(1, "字符串", true, new Test())

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

3、元组

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

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

日志打印:

4、集合

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

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

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

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

  1. let test
  2. console.log(typeof test)

控制台打印如下:

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

  1. let test
  2. if (test != undefined) {
  3. console.log("有值")
  4. } else {
  5. console.log("无值")
  6. }

六、空null

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

  1. let test=null
  2. console.log(test)

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

如下比较:

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

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

null和undefined进行比较

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

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

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

九、相关总结

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

  1. let test// any
  2. test = 0
  3. test = "字符串"
  4. test = true
  5. console.log(test)

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

关于数据类型中的元组、数组、集合,本篇文章只是作为一个简单的了解,而关于类型操作,比如获取,删除等等,我们在接下来的文章中再做概述,希望大家可以持续关注。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/339360
推荐阅读
相关标签
  

闽ICP备14008679号