系統(tǒng)學(xué)習(xí) TypeScript(四)——變量聲明的初步學(xué)習(xí)

TypeScript

前言

認(rèn)識(shí)了 TypeScript 中的基礎(chǔ)類型,接下來(lái)當(dāng)然是變量聲明的相關(guān)學(xué)習(xí)了。

聲明多維數(shù)組

假如有這么一個(gè)聲明:

let arr3: number[][][];

想要知道 arr3 的具體類型,其分析步驟如下:

image-20220225151900823

可以看到,類型拆解是從右向左的赞咙,對(duì)應(yīng)到具體變量值上就是從外向內(nèi)一層層拆解的。

這里只是舉個(gè)例子糟港,稍微有點(diǎn)經(jīng)驗(yàn)的人一眼就能判斷出 arr3 是一個(gè)三維數(shù)組攀操。但是,授人以魚(yú)不如授人以漁秸抚,這個(gè)分析方法卻適用于絕大多數(shù)復(fù)雜數(shù)據(jù)類型分析速和。

屬性重命名

在有了 ES6 的解構(gòu)賦值之后,我們可以這么聲明變量:

let personInfo1 = {
    name: "編程三昧",
    age:22
}
let {name: nameP, age: ageP} = personalInfo1;

以上代碼聲明了 nameP 和 ageP 兩個(gè)變量剥汤。需要注意的是:變量聲明中颠放,冒號(hào)后面跟的不是數(shù)據(jù)類型,而是新聲明來(lái)替代原對(duì)象屬性值的變量吭敢。

如果在 TypeScript 中碰凶,要指定 nameP 和 ageP 的數(shù)據(jù)類型,需要這么寫:

let { name: nameP, age: ageP }: { name: string; age: number } = personInfo1;

其實(shí)這個(gè)類型指定可以放在對(duì)象聲明中,指定對(duì)象每一項(xiàng)屬性值的類型:

let personInfo1: { name: string; age: number } = {
    name: "編程三昧",
    age: 22
};

personInfo1.name = 12; // Error 不能將類型“number”分配給類型“string”

// let {name: nameP, age: ageP} = personInfo1;
let { name: nameP, age: ageP } = personInfo1;

nameP = 12; // Error 不能將類型“number”分配給類型“string”

let 和 const 的暫時(shí)性死區(qū)

以下代碼在 TypeScript 中不會(huì)報(bào)錯(cuò)欲低,但是在實(shí)際運(yùn)行中會(huì)報(bào)錯(cuò)辕宏。

function foo(): number {
    return a1;
}
foo();

let a1: number = 12;

實(shí)際運(yùn)行報(bào)錯(cuò):

image-20220225144916570

我自己的理解是:靜態(tài)編譯時(shí)只負(fù)責(zé)檢測(cè)數(shù)據(jù)類型是否正確,而動(dòng)態(tài)運(yùn)行時(shí)才會(huì)檢測(cè)語(yǔ)法邏輯錯(cuò)誤砾莱,恰好暫時(shí)性死區(qū)是在運(yùn)行時(shí)才產(chǎn)生的瑞筐。

總結(jié)

以上就是我在學(xué)習(xí) TypeScript 變量聲明時(shí)所記錄的注意事項(xiàng)和總結(jié)。

~

~ 本文完腊瑟,感謝閱讀聚假!

~

學(xué)習(xí)有趣的知識(shí),結(jié)識(shí)有趣的朋友闰非,塑造有趣的靈魂膘格!

大家好,我是〖編程三昧〗的作者 隱逸王财松,我的公眾號(hào)是『編程三昧』瘪贱,歡迎關(guān)注,希望大家多多指教游岳!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末政敢,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子胚迫,更是在濱河造成了極大的恐慌喷户,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件访锻,死亡現(xiàn)場(chǎng)離奇詭異褪尝,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)期犬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門河哑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人龟虎,你說(shuō)我怎么就攤上這事璃谨。” “怎么了鲤妥?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵佳吞,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我棉安,道長(zhǎng)底扳,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任贡耽,我火速辦了婚禮衷模,結(jié)果婚禮上鹊汛,老公的妹妹穿的比我還像新娘。我一直安慰自己阱冶,他們只是感情好刁憋,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著熙揍,像睡著了一般职祷。 火紅的嫁衣襯著肌膚如雪氏涩。 梳的紋絲不亂的頭發(fā)上届囚,一...
    開(kāi)封第一講書(shū)人閱讀 51,292評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音是尖,去河邊找鬼意系。 笑死,一個(gè)胖子當(dāng)著我的面吹牛饺汹,可吹牛的內(nèi)容都是我干的蛔添。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼兜辞,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼迎瞧!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起逸吵,我...
    開(kāi)封第一講書(shū)人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤凶硅,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后扫皱,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體足绅,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年韩脑,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了氢妈。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡段多,死狀恐怖首量,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情进苍,我是刑警寧澤加缘,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站琅捏,受9級(jí)特大地震影響生百,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜柄延,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一蚀浆、第九天 我趴在偏房一處隱蔽的房頂上張望缀程。 院中可真熱鬧,春花似錦市俊、人聲如沸杨凑。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)撩满。三九已至,卻和暖如春绅你,著一層夾襖步出監(jiān)牢的瞬間伺帘,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工忌锯, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留伪嫁,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓偶垮,卻偏偏與公主長(zhǎng)得像张咳,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子似舵,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354

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