1.布尔值boolean
最基本的数据类型就是简单的true/false值
let isDone: boolean = false;
2.数字number
和JavaScript一样,TypeScript里的所有数字都是浮点数。 这些浮点数的类型是 number
。 除了支持十进制和十六进制字面量,TypeScript还支持ECMAScript 2015中引入的二进制和八进制字面量。
let decLiteral: number = 6;
let hexLiteral: number = 0xf00d;
let binaryLiteral: number = 0b1010;
let octalLiteral: number = 0o744;
3.字符串string
我们使用string
表示文本数据类型。 和JavaScript一样,可以使用双引号( ")或单引号(')表示字符串。
let name: string = "bob";
name = "smith";
你还可以使用模版字符串,它可以定义多行文本和内嵌表达式。 这种字符串是被反引号包围( `),并且以${ expr }这种形式嵌入表达式
let name: string = `Gene`;
let age: number = 37;
let sentence: string = `Hello, my name is ${ name }.I'll be ${ age + 1 } years old next month.`;
4.数组
定义数组的两种方式:
(1)元素类型后面接上 []
,表示由此类型元素组成的一个数组
let list: number[] = [1, 2, 3];
(2)使用数组泛型,Array<元素类型>
:
let list: Array = [1, 2, 3];
5.元组Tuple:
元组类型允许表示一个已知元素数量和类型的数组,各元素的类型不必相同
。 比如,你可以定义一对值分别为 string
和number
类型的元组。
// Declare a tuple type
let x: [string, number];
// Initialize it
x = ['hello', 10]; // OK
// Initialize it incorrectly
x = [10, 'hello']; // Error
//注:元组中不同类型的数据位置不可改变
当访问一个已知索引的元素,会得到正确的类型:
console.log(x[0].substr(1)); // OK
console.log(x[1].substr(1)); // Error, 'number' does not have 'substr'
当访问一个越界的元素,会使用联合类型(元组中已定义过的数据类型
)替代:
x[3] = 'world'; // OK, 字符串可以赋值给(string | number)类型
console.log(x[5].toString()); // OK, 'string' 和 'number' 都有 toString
x[6] = true; // Error, 布尔不是(string | number)类型
6.枚举enum
enum Color {Red, Green, Blue}
let c: Color = Color.Green;
查找相应的名字:
enum Color {Red = 1, Green, Blue}
let colorName: string = Color[2];
console.log(colorName); // 显示'Green'因为上面代码里它的值是2
7.Any 任意类型
let notSure: any = 4;
notSure = "maybe a string instead";
notSure = false; // okay, definitely a boolean
//变量,数组等 不知道具体数据类型时都可以使用
8.Null 和 Undefined
默认情况下
nul
l和undefined
是所有类型的子类型。 就是说你可以把null
和undefined
赋值给number
类型的变量。
然而,当你指定了--strictNullChecks
标记,null
和undefined
只能赋值给void
和它们各自。
9.Never
never
类型表示的是那些永不存在的值的类型。
例如,
never
类型是那些总是会抛出异常或根本就不会有返回值的函数表达式或箭头函数表达式的返回值类型;
10.Object
object
表示非原始类型,也就是除number
,string
,boolean
,symbol
,null
或undefined
之外的类型。
类型断言
用途:手动指定一个值的类型,但断言成一个联合类型中不存在的类型是不允许的
function toBoolean(something: string | number): boolean {
return something;
}
// Type 'string | number' cannot be converted to type 'boolean'
两种方法:
(1)“尖括号”语法:
let someValue: any = "this is a string";
let strLength: number = (someValue).length;
(2)as
语法:
let someValue: any = "this is a string";
let strLength: number = (someValue as string).length;