- 數(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ù)類型的元素
- 各項(xiàng)元素類型已知
- 當(dāng)訪問一個(gè)已知索引的元素,會(huì)得到正確的類型
- 當(dāng)訪問越界的元素時(shí),會(huì)使用聯(lián)合類型替代(不存在的元素會(huì)具有所有聲明元素的共有的方法)
let x: [string, number] = ['hello', 100]; // OK
let y: [string, number] = [12, 'world'] // Error (incorrectly)
x[3] = '張三' //ok 字符串可以賦值給(string | number)類型
x[6] = true; // Error, 布爾不是(string | number)類型
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ù)類型時(shí),且為了讓其通過編譯和檢查,可以定義數(shù)據(jù)類型為any
- Object類型的變量只是允許你給它賦任意值 , 但是卻不能夠在它上面調(diào)用任意的方法,即便它真的有這些方法。
- 當(dāng)你只知道一部分?jǐn)?shù)據(jù)的類型時(shí),any類型也是有用的
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類型像是與any類型相反,它表示沒有任何類型。 當(dāng)一個(gè)函數(shù)沒有返回值時(shí),通常其返回值類型是 void
- 聲明一個(gè)void類型的變量沒有什么大用,因?yàn)槟阒荒転樗x予undefined和null
function sayHello(): void {
console.log(" hellow world")
}
let unusable: void = undefined;
- null 和undefind
- undefined和null兩者各自有自己的類型分別叫做undefined和null
- 默認(rèn)情況下null和undefined是所有類型的子類型。 就是說(shuō)你可以把 null和undefined賦值給number類型的變量
- 當(dāng)指定了--strictNullChecks標(biāo)記,null和undefined只能賦值給void和它們各自。
let u: undefined = undefined;
let n: null = null;
- never
- never類型表示的是那些永不存在的值的類型
- never類型通常用來(lái)定義: 總是會(huì)拋出異常 或 根本就不會(huì)有返回值的函數(shù)表達(dá)式 或 箭頭函數(shù)表達(dá)式的返回值類型。
- 變量也可能是 never類型,當(dāng)它們被永不為真的類型保護(hù)所約束時(shí)。
// 返回never的函數(shù)必須存在無(wú)法達(dá)到的終點(diǎn)
function error(message: string): never {
throw new Error(message);
}
// 推斷的返回值類型為never
function fail() {
return error("Something failed");
}
// 返回never的函數(shù)必須存在無(wú)法達(dá)到的終點(diǎn)
function infiniteLoop(): never {
while (true) {
}
}
- object
- object表示非原始類型,也就是除number,string,boolean,symbol,null或undefined之外的類型。
declare function create(o: object | null): void;
- 類型斷言
- 類型斷言好比其它語(yǔ)言里的類型轉(zhuǎn)換,但是不進(jìn)行特殊的數(shù)據(jù)檢查和解構(gòu)。 它沒有運(yùn)行時(shí)的影響,只是在編譯階段起作用
- 類型斷言有兩種形式。 其一是“尖括號(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