boolean,可以定义为true/false
let isDone: boolean = false
number,所有的数字都是浮点数,支持十进制,十六进制,二进制和八进制
let decLiteral: number = 6;
let hexLiteral: number = 0xf00d;
let binaryLiteral: number = 0b1010;
let octalLiteral: number = 0o744;
string,可以使用双引号("")、单引号('')和反引号(`` )表示
let name: string = 'bob';
let sex: string = "male";
let sentence: string = `hello, my name is ${name}`;
有两种方法可以定义数组
在元素类型后面接上[],表示由此类型元素组成一个数组
元组类型允许表示一个已知元素数量和类型的数组,各元素的类型不必相同,比如你可以定义一对值分别为string和number类型的元组
当访问一个一直索引的元素,会得到正确的类型
当访问一个跨界的元素,会使用联合类型替代
enum类型是对JavaScript标准数据类型的一个补充
默认情况下,从0开始为元素编号,你也可以手动指定成员的数值。例如,我们将上面的例子改成从1开始编号:
也可以全部手动赋值
any,有时候,我们会想要为那些在编程阶段还不清楚类型的变量指定一个类型。这些值可能来子推燕动态的内容,比如用户输入或者第三方代码库。这种情况下,我们不希望类型检查器对这些值进行检查而是直接让他们通过编译阶段的检查,那我们就可使用any类型来标记这些变量:
在对现有代码进行改写的时候,any类型是十分有用的。他允许你在变异时可选择地包含或移除类型检查。你可能认为Object有相似的作用,就想他在其他语言中的那样。但是Object类型的变量只是允许你给他赋任意值,但是却不能够在他上面调用任何方法,几遍他真的有这些方法:
当你只知道一部分数据类型时,any类型也是有用的。比如,你有一个数组,他包含了不同的类型的数据:
void,某种程度上来说void类型和any类型相反,他标书没有任何类型。当一个函数没有返回之时,你通常会见到其返回值类型为void:
声明一个void类型的变量没有什么大用,因为你指能赋予它undefined和null
9. Null 和 Undefined
null的类型就是null
undefined的类型就是undefined
和void相似,他们本身的类型用处不是很大:
默认情况下,null和undefined是所有类型的子类型,也就是说你可以把null和undefined赋值给number类型的变量
然而,当你制定了--strictNullChecks标记时,null和undefined只能赋值给void和他们各自。这能避免很多常见的问题,允许在某处你想传入一个string或null或undefined,你可以使用联合类型string | null | undefined。
注意: 我们应该尽可能的使用 --strictNullChecks
never类型表示哪些用不存在值得类型,例如:never类型是那些总会抛出异常或根本就不会有返回值的函数表达式或箭头函数表达式的返回值类型;变量也可能是never类型,当他们被用不为真的类型保护所约束时。
never类型是任意类型的子类型,也可以赋值给任意类型;然而,没有类型是never的子类型或可以赋值给never类型,(除了never本身之外)。即使any也不可以赋值给never。
下面是一些返回never类型的函数:
object表示非原始类型,也就是除number,string,boolean,symbol,null或undefined之外的类型。使用object类型,就可以更好的表示像Object.create这样的 API,例如:
有些时候,你会比TypeScript更了解某个值的详细信息,通常这会发生在你清楚地知道一个实体具有比他现有类型更确切的类型。
通过类型断言这种方式告诉编译器,“相信我,我知道自己在干什么”。类型断言好比其他语言中的类型转换,但是不进行特殊的数据检查和结构。他没有运行时的影响,只在编译阶段起作用, TypeScript 会假设你已经进行了必须的检查。
类型断言有两种形式:
两种形式是等价的。至于使用哪种写法全凭个人喜好;然而,当你在TypeScript里使用JSX时,只有as语法断言是被允许的。