- 數(shù)字 number
let age: number = 24;
let double_age: number = 48;
- 字符串 string
let words: string = "what's is your question?";
let sport_name: string = 'football';
const name:string = '張三';
const sentence: string = `my name is ${ name }, my favorite sport is ${ sport_name }`;
- 布爾值 boolean
let is_right: boolean = true;
- 數(shù)組 Array
方式一:
let user_list: string[] = ['張三', '李四', '老六'];
let temperatures: number[] = [12, 15, 24, 25];
方式二:
let user_list: Array<string> = ['張三', '李四', '老六'];
let temperatures: Array<number> = [12, 15, 24, 25];
- 元祖 Tuple
- 不同數(shù)據(jù)類(lèi)型的元素
- 各項(xiàng)元素類(lèi)型已知
- 當(dāng)訪問(wèn)一個(gè)已知索引的元素,會(huì)得到正確的類(lèi)型
- 當(dāng)訪問(wèn)越界的元素時(shí),會(huì)使用聯(lián)合類(lèi)型替代(不存在的元素會(huì)具有所有聲明元素的共有的方法)
let x: [string, number] = ['hello', 100]; // OK
let y: [string, number] = [12, 'world'] // Error (incorrectly)
x[3] = '張三' //ok 字符串可以賦值給(string | number)類(lèi)型
x[6] = true; // Error, 布爾不是(string | number)類(lèi)型
console.log(x[0].substr(1)); // OK
console.log(x[1].substr(1)); // Error, 'number' does not have 'substr'
console.log(x[5].toString()) // OK, 'string' 和 'number' 都有 toString
- 枚舉 enum
enum Color {Red = 1, Green = 2, Blue = 4}
let c: Color = Color.Green;
let colorName: string = Color[2];
console.log(colorName); // 顯示'Green'因?yàn)樯厦娲a里它的值是2
- Any
- 當(dāng)我們不清楚當(dāng)前變量的數(shù)據(jù)類(lèi)型時(shí),且為了讓其通過(guò)編譯和檢查,可以定義數(shù)據(jù)類(lèi)型為any
- Object類(lèi)型的變量只是允許你給它賦任意值 , 但是卻不能夠在它上面調(diào)用任意的方法,即便它真的有這些方法。
- 當(dāng)你只知道一部分?jǐn)?shù)據(jù)的類(lèi)型時(shí),any類(lèi)型也是有用的
let not_sure: any = 6;
not_sure = 'i'm not sure what is it '
not_sure = false
not_sure = 100.666665
not_sure.toFixed(2) // OK toFixed exists (but the compiler doesn't check)
let prettySure: Object = 4;
prettySure.toFixed(); // Error: Property 'toFixed' doesn't exist on type 'Object'
let list: any[] = [1, true, "free"];
list[1] = 100;
- void
- void類(lèi)型像是與any類(lèi)型相反,它表示沒(méi)有任何類(lèi)型。 當(dāng)一個(gè)函數(shù)沒(méi)有返回值時(shí),通常其返回值類(lèi)型是 void
- 聲明一個(gè)void類(lèi)型的變量沒(méi)有什么大用,因?yàn)槟阒荒転樗x予undefined和null
function sayHello(): void {
console.log(" hellow world")
}
let unusable: void = undefined;
- null 和undefind
- undefined和null兩者各自有自己的類(lèi)型分別叫做undefined和null
- 默認(rèn)情況下null和undefined是所有類(lèi)型的子類(lèi)型。 就是說(shuō)你可以把 null和undefined賦值給number類(lèi)型的變量
- 當(dāng)指定了--strictNullChecks標(biāo)記,null和undefined只能賦值給void和它們各自。
let u: undefined = undefined;
let n: null = null;
- never
- never類(lèi)型表示的是那些永不存在的值的類(lèi)型
- never類(lèi)型通常用來(lái)定義: 總是會(huì)拋出異常 或 根本就不會(huì)有返回值的函數(shù)表達(dá)式 或 箭頭函數(shù)表達(dá)式的返回值類(lèi)型。
- 變量也可能是 never類(lèi)型,當(dāng)它們被永不為真的類(lèi)型保護(hù)所約束時(shí)。
// 返回never的函數(shù)必須存在無(wú)法達(dá)到的終點(diǎn)
function error(message: string): never {
throw new Error(message);
}
// 推斷的返回值類(lèi)型為never
function fail() {
return error("Something failed");
}
// 返回never的函數(shù)必須存在無(wú)法達(dá)到的終點(diǎn)
function infiniteLoop(): never {
while (true) {
}
}
- object
- object表示非原始類(lèi)型,也就是除number,string,boolean,symbol,null或undefined之外的類(lèi)型。
declare function create(o: object | null): void;
- 類(lèi)型斷言
- 類(lèi)型斷言好比其它語(yǔ)言里的類(lèi)型轉(zhuǎn)換,但是不進(jìn)行特殊的數(shù)據(jù)檢查和解構(gòu)。 它沒(méi)有運(yùn)行時(shí)的影響,只是在編譯階段起作用
- 類(lèi)型斷言有兩種形式。 其一是“尖括號(hào)”語(yǔ)法,另一種是as語(yǔ)法
let someValue: any = "this is a string";
let strLength: number = (<string>someValue).length; // 將someValue斷言為string后取string的length
let someValue: any = "this is a string";
let strLength: number = (someValue as string).length // 將someValue斷言為string后取string的length