前言
无论是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。
局部声明须带关键字
            
            
              TypeScript
              
              
            
          
              let a: number = 0 //整数
    let b: number = -100 //负数
    let c: number = 88.88 //小数
    let d: number = 0b1010 //二进制 ES6
    let e: number = 0o744 //八进制  ES6
        成员声明不带关键字
            
            
              TypeScript
              
              
            
          
            a: number = 0 //整数
  b: number = -100 //负数
  c: number = 88.88 //小数
  d: number = 0b1010 //二进制
  e: number = 0o744 //八进制
        需要注意的是TypeScript中有类型推断功能,类型可以不写也不会报错,为了避免冗余,日后的书写也建议舍弃类型,标准如下:
局部声明
            
            
              TypeScript
              
              
            
          
              let a = 0 //整数
    let b = -100 //负数
    let c = 88.88 //小数
    let d = 0b1010 //二进制
    let e = 0o744 //八进制
        成员声明
            
            
              TypeScript
              
              
            
          
            a = 0 //整数
  b = -100 //负数
  c = 88.88 //小数
  d = 0b1010 //二进制
  e = 0o744 //八进制
        当然了以上的前提必须拥有默认值,如果不定义默认值,其类型可携带可不携带,但是为了确定类型,方便之后的代码调用,建议还是带上类型比较好,如下:
局部声明
            
            
              TypeScript
              
              
            
          
              let a:number 
    let b:number
    let c:number
    let d:number
    let e:number
        成员声明
            
            
              TypeScript
              
              
            
          
            a: number
  b: number
  c: number
  d: number
  e: number
        如果没有声明类型,也不会报错,那么它是一个不确定类型any,后续可以赋值任何类型数据。
二、布尔类型boolean
布尔类型没什么好说的,用于标识true和false。
局部声明
            
            
              TypeScript
              
              
            
          
          //带默认值
let isBoolean: boolean = false
//类型推断后省略类型写法
let isBoolean = false
//不带默认值
let isBoolean: boolean
        成员声明
            
            
              TypeScript
              
              
            
          
          //带默认值
isBoolean: boolean = false
//类型推断后省略类型写法
isBoolean = false
//不带默认值
isBoolean: boolean
        其他使用方式跟number类型基本一致。
三、字符串类型string
字符串使用,可单引号也可双引号,都是表示一个字符串。
局部声明
            
            
              TypeScript
              
              
            
          
          //带默认值
let singleQuotes: string = '单引号字符串'
let doubleQuotes: string = "双引号字符串"
//类型推断后省略类型写法
let singleQuotes = '单引号字符串'
let doubleQuotes = "双引号字符串"
//不带默认值
let singleQuotes: string
let doubleQuotes: string
        成员声明
            
            
              TypeScript
              
              
            
          
          //带默认值
singleQuotes: string = '单引号字符串'
doubleQuotes: string = "双引号字符串"
//类型推断后省略类型写法
singleQuotes = '单引号字符串'
doubleQuotes = "双引号字符串"
//不带默认值
singleQuotes: string
doubleQuotes: string
        其他使用方式跟number类型基本一致。
四、对象object
在ArkTs中,不管你是一个普通的对象,还是一个数组,元组,集合等等,都是一个对象类型。
            
            
              TypeScript
              
              
            
          
              let obj = { "name": "AbnerMing" }
    let test: Test = new Test()
    let numberArray = [1, 2, 3, 4, 5]
    let numberArrayObj = new Array<number>()
    let tuple: [string, number] = ["age", 10]
    let list = new ArrayList<number>()
    let map = new HashMap<string, number>()
    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方法进行获取,也有私有和公共关键字。
            
            
              TypeScript
              
              
            
          
          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
  }
}
        使用方式:
            
            
              TypeScript
              
              
            
          
              let test = new Test()
    test.setName("AbnerMing")
    test.setAage(10)
    let name = test.getName()
    let age = test.getAge()
        如果没有特别的要求,也可以不用get和set方法:
            
            
              TypeScript
              
              
            
          
          export class Test {
  name: string
  age: number
}
        使用方式:
            
            
              TypeScript
              
              
            
          
              let test = new Test()
    test.name = "AbnerMing"
    test.age = 10
    let name = test.name
    let age = test.age
        除了以上的对象创建和使用之外,在ArkTs中也支持直接花括号的形式声明:
            
            
              TypeScript
              
              
            
          
              let test = { "name": "AbnerMing", "age": 10 }
    let name = test.name
    let age = test.age
        2、数组
数组有两种声明方式,一种是使用Array对象,一种直接使用中括号[]。
            
            
              TypeScript
              
              
            
          
          let array = Array<number>()
let arr = []
        默认值
            
            
              TypeScript
              
              
            
          
              let arr = [1, 2, 3, 4, 5]
    let array = Array<number>(1, 2, 3, 4, 5)
        数组如果没声明类型,它是可以并存多种类型数据的,如下所示:
            
            
              TypeScript
              
              
            
          
              let arr = [1, "字符串", true, new Test()]
    let array = Array<any>(1, "字符串", true, new Test())
        所以在以后的开发中,对于数组而言,大家尽量精确数据类型,方便后续的使用,针对数组的操作,比如增删改查,后续的文章会有讲解,大家可以持续关注。
3、元组
如果存储的元素数据类型不同,则需要使用元组,元组中允许存储不同类型的元素,元组可以作为参数传递给函数。
            
            
              TypeScript
              
              
            
          
              let tuple = ["AbnerMing", 10]
    console.log("key:" + tuple[0])
    console.log("value:" + tuple[1])
        日志打印:

4、集合
无论是单列集合list,还是双列集合map,都吸取了Java中的优点,基本关于集合操作的方法,在ArkTs中该有的都有,本篇就不过多的介绍了。
五、未定义或不存在的值undefined
当你定义了一个变量而为赋值时,那么它就是undefined。
比如我定义了一个变量,而为进行赋值,如下:
            
            
              TypeScript
              
              
            
          
              let test
    console.log(typeof test)
        控制台打印如下:

那么在以后的开发中,如果你不确定某个数据是否有值,无论对象还是其他类型,都可以进行undefined判断:
            
            
              TypeScript
              
              
            
          
          let test
if (test != undefined) {
   console.log("有值")
} else {
   console.log("无值")
}
        六、空null
null是一个表示"空值"的对象,通常用来表示变量的值为"没有值",如果需要明确表示一个变量的值为空,就可以使用 null。
            
            
              TypeScript
              
              
            
          
          let test=null
console.log(test)
        上述的打印结果为null,和undefined不同的是,需要设置为null,如果不设置就是undefined,需要注意的是,null 和 undefined 在进行比较时,它们的值相等,但数据类型不同。
如下比较:
            
            
              TypeScript
              
              
            
          
          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的超集,针对数据类型,说强它则强,说不强也不强,比如,一个变量,如未指定数据类型,它可以进行任何类型赋值,以最后一个赋值为最终结果。
            
            
              TypeScript
              
              
            
          
              let test// any
    test = 0
    test = "字符串"
    test = true
    console.log(test)
        上述则会打印true,所有在以后的开发中,大家尽量要对数据进行类型限制,既方便与类型区分,也方便错误的甄别,更加有利于代码的健壮。
关于数据类型中的元组、数组、集合,本篇文章只是作为一个简单的了解,而关于类型操作,比如获取,删除等等,我们在接下来的文章中再做概述,希望大家可以持续关注。