1-typescript基本數(shù)據(jù)類型

  1. 數(shù)字 number
let age: number = 24;
let double_age: number = 48;
  1. 字符串 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 }`;
  1. 布爾值 boolean
let is_right: boolean = true;
  1. 數(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];

  1. 元祖 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
  1. 枚舉 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
  1. 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;
  1. 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;
  1. 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;
  1. 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) {
    }
}
  1. object
  • object表示非原始類型,也就是除number,string,boolean,symbol,null或undefined之外的類型。
declare function create(o: object | null): void;
  1. 類型斷言
  • 類型斷言好比其它語(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
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容