ts 學(xué)習(xí) -- 基本數(shù)據(jù)類型

布爾值、數(shù)字爷贫、字符串认然、數(shù)組补憾、元組、枚舉卷员、Any盈匾、Void、Null毕骡、Undefined削饵、Never、Object
let 變量名稱 :變量類型 = 值 挺峡;//值的類型必須與變量類型一致葵孤,否則提示錯(cuò)誤

  • 數(shù)組担钮、元組橱赠、枚舉
1 //數(shù)組
2 let list: number[] = [1,2,3];//list變量是一個(gè)數(shù)組,只要賦值數(shù)組就沒問題
3 let numList: Array<number> = [1,2,3];//泛型數(shù)組箫津,賦值的數(shù)組每個(gè)元素類型必須符合指定的泛型類型
4 let strList: Array<string> = ["1","2","3"];//這是一個(gè)字符串泛型數(shù)組 
5 let names:string[] = ['小明','小紅'];//字符串泛型數(shù)組-簡寫
6 let arr:[string,number] = ['1',2]; //元組:聲明數(shù)組時(shí)指定數(shù)組的每一個(gè)元素類型狭姨,并且數(shù)組長度不能超出變量聲明時(shí)指定的元素個(gè)數(shù)

TypeScript中的枚舉(enum)非常友好的提供了一個(gè)有窮序列集的數(shù)據(jù)結(jié)構(gòu),它會(huì)默認(rèn)從0開始給每個(gè)元素編號苏遥,可以通過元素獲取編號饼拍,也可以通過編號獲取元素名稱,然而其內(nèi)部實(shí)現(xiàn)采用的是犧牲空間換時(shí)間的方式田炭,比如枚舉Color中有一個(gè)元素Blue,底層實(shí)現(xiàn)方式是{Blue:0,0:'Blue'},這就實(shí)現(xiàn)了當(dāng)要查找值對應(yīng)的元素時(shí)只需要Color[0]就能獲取师抄,而如果在前的數(shù)組或?qū)ο笾幸氆@得值對應(yīng)的元素就只能遍歷數(shù)組或者對象來實(shí)現(xiàn)。

1 //枚舉
 2 enum Color {
 3     Red,
 4     Green,
 5     Blue
 6 }
 7 console.log(Color.Red);//0
 8 //自定義編號或者值:編號只能為數(shù)值,元素為字符串
 9 enum Name {
10     xiaoming = 3,
11     xiaohong = 5
12 }
13 console.log(Name[3]);//'xiaoming'
14 //枚舉同樣不能越界,只能在枚舉有限集合中查找
15 Color.Yellow = 4; //報(bào)錯(cuò)(2339):類型上找不到‘Yellow’該屬性
  • 任意類型(any)與無效類型(Void)
1 //any類型:同等與JavaScript的變量教硫,變量的類型取決于值的類型叨吮,并且可以任意變化
2 let notSure: any = 4;
3 notSure = "maybe a string instead";
4 notSure = false;

這里可能會(huì)疑惑Any這個(gè)變量類型有什么用?這不又回到了JavaScript了嗎瞬矩?的確茶鉴,它可以幫助我們回歸到JavaScript變量類型模式,這就意味著我們?nèi)绻谧鲰?xiàng)目升級時(shí)景用,在遇到無法確定的變量類型我們就可以使用Any涵叮;還有就是第三方庫或者用戶輸入的數(shù)據(jù),我們也可能無法確定其類型伞插,這時(shí)候就可以解決這類問題割粮。
還有一個(gè)很關(guān)鍵的應(yīng)用就是TypeScript中的數(shù)組,前面的Array語法中如果需要一個(gè)元素類型不相同的數(shù)組我們只能使用元組來實(shí)現(xiàn)媚污,但是元組有約束了下標(biāo)和長度舀瓢,還是可能無法完成一些特殊的需求,特別是對于習(xí)慣JavaScript的寬松的數(shù)組模式杠步,Any可以幫助TtypeScript實(shí)現(xiàn)同等JavaScript的數(shù)組:

let list: any[] = ['hello',100,true];

void類型用處就不大了氢伟,它用來表示沒有任何類型榜轿,其作用就是用來描述沒有類型,在一定程度上它同等與undefinde朵锣。

1 //void變量值始終為undefined
2 let a: void = undefined;
3 function foo(): void {//用來表示函數(shù)不返回任何值
4     // return void ...;以前我們可以這樣表示函數(shù)不返回任何值
5     // 之前javaScript的寫法不會(huì)有錯(cuò)誤檢查谬盐,閱讀代碼時(shí)需要查看函數(shù)內(nèi)部代碼
6 }
  • undefined、null
    用來指定變量只能為undefined和null的值诚些,undefined和null變量類型在TypeScript中還有一個(gè)含義飞傀,它們可以作為任何變量的子集,當(dāng)然這時(shí)在tsconfig.json的"strictNullChecks": false的情況下诬烹。
1 let a:undefined = undefined;
2 let b:null = null;
3 let c: number = 10;
4 c = undefined;
5 c = null;
6 // tsconfig.json -- "strictNullChecks": false模式 
  • never
    用來表示那些永遠(yuǎn)不存在的值的類型砸烦。比如拋出錯(cuò)誤,這種情況通常出現(xiàn)在錯(cuò)誤檢查中绞吁。變量也可以是never類型幢痘,但是賦值除了自身類型以外的任何變量類型都會(huì)提示錯(cuò)誤。
 1 //1.拋出異常
 2 function error(message: string): never {
 3     throw new Error(message);
 4 }
 5 //死循環(huán)
 6 function loop(): never {
 7     while (true){}
 8 }
 9 //never是所有類型的子集家破,例如作為number的子集:
10 let a: number;
11 y = (() => { throw new Error 'message' })();
  • 函數(shù)類型function
1 function add1(x:number,y:number):number{
2   return x+y;
3 }
4 
5 let add2 = function(x:number,y:number):number{
6   return x + y;
7 }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末颜说,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子汰聋,更是在濱河造成了極大的恐慌门粪,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,590評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件烹困,死亡現(xiàn)場離奇詭異玄妈,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)髓梅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,157評論 3 399
  • 文/潘曉璐 我一進(jìn)店門拟蜻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人女淑,你說我怎么就攤上這事瞭郑。” “怎么了鸭你?”我有些...
    開封第一講書人閱讀 169,301評論 0 362
  • 文/不壞的土叔 我叫張陵屈张,是天一觀的道長。 經(jīng)常有香客問我袱巨,道長阁谆,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,078評論 1 300
  • 正文 為了忘掉前任愉老,我火速辦了婚禮场绿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘嫉入。我一直安慰自己焰盗,他們只是感情好璧尸,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,082評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著熬拒,像睡著了一般爷光。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上澎粟,一...
    開封第一講書人閱讀 52,682評論 1 312
  • 那天蛀序,我揣著相機(jī)與錄音,去河邊找鬼活烙。 笑死徐裸,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的啸盏。 我是一名探鬼主播重贺,決...
    沈念sama閱讀 41,155評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼宫补!你這毒婦竟也來了檬姥?” 一聲冷哼從身側(cè)響起曾我,我...
    開封第一講書人閱讀 40,098評論 0 277
  • 序言:老撾萬榮一對情侶失蹤粉怕,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后抒巢,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體贫贝,經(jīng)...
    沈念sama閱讀 46,638評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,701評論 3 342
  • 正文 我和宋清朗相戀三年蛉谜,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了稚晚。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,852評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡型诚,死狀恐怖客燕,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情狰贯,我是刑警寧澤也搓,帶...
    沈念sama閱讀 36,520評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站涵紊,受9級特大地震影響傍妒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜摸柄,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,181評論 3 335
  • 文/蒙蒙 一颤练、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧驱负,春花似錦嗦玖、人聲如沸患雇。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,674評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽庆亡。三九已至,卻和暖如春捞稿,著一層夾襖步出監(jiān)牢的瞬間又谋,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,788評論 1 274
  • 我被黑心中介騙來泰國打工娱局, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留彰亥,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,279評論 3 379
  • 正文 我出身青樓衰齐,卻偏偏與公主長得像任斋,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子耻涛,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,851評論 2 361

推薦閱讀更多精彩內(nèi)容