TypeScript基礎(chǔ)一(安裝 TypeScript,原始數(shù)據(jù)類型甜无,任意值扛点,類型推論)

安裝 TypeScript

執(zhí)行命令行

npm install -g typescript

會(huì)在全局環(huán)境下安裝 tsc 命令,安裝完成之后岂丘,我們就可以在任何地方執(zhí)行 tsc 命令了陵究。
編譯一個(gè) TypeScript 文件很簡單:

tsc hello.ts

我們約定使用 TypeScript 編寫的文件以 .ts 為后綴,用 TypeScript 編寫 React 時(shí)元潘,以 .tsx 為后綴畔乙。

原始數(shù)據(jù)類型

JavaScript 的類型分為兩種:原始數(shù)據(jù)類型(Primitive data types)和對象類型(Object types)。
原始數(shù)據(jù)類型包括:布爾值翩概、數(shù)值牲距、字符串、null钥庇、undefined 以及 ES6 中的新類型 Symbol牍鞠。
本節(jié)主要介紹前五種原始數(shù)據(jù)類型在 TypeScript 中的應(yīng)用。

  • 布爾值

let isDone: boolean = false;
  • 數(shù)值

let decLiteral: number = 6;
  • 字符串

let myName: string = 'Tom';
// 模板字符串
let sentence: string = `Hello, my name is ${myName}.
I'll be ${myAge + 1} years old next month.`;
  • Null 和 Undefined

let u: undefined = undefined;
let n: null = null;

tips:undefined 和 null 是所有類型的子類型评姨。也就是說 undefined 類型的變量难述,可以賦值給 其他 類型的變量,例如賦值給number類型的變量:

// 這樣不會(huì)報(bào)錯(cuò)
let num: number = undefined;
// 這樣也不會(huì)報(bào)錯(cuò)
let u: undefined;
let num: number = u;
  • 空值

JavaScript 沒有空值(Void)的概念吐句,在 TypeScript 中胁后,我們用 void 表示沒有任何返回值的函數(shù):

function alertName(): void {
    alert('My name is Tom');
}

任意值

字面意思就是允許賦值為所有類型,包括簡單數(shù)據(jù)類型和復(fù)雜數(shù)據(jù)類型嗦枢。
對于普通數(shù)據(jù)類型攀芯,在賦值過程中是不可以改變類型的,否則會(huì)報(bào)錯(cuò):

let myFavoriteNumber: string = 'seven';
myFavoriteNumber = 7;

// index.ts(2,1): error TS2322: Type 'number' is not assignable to type 'string'.

但如果是any類型文虏,賦值過程中改變類型是允許的:

let myFavoriteNumber: any = 'seven';
myFavoriteNumber = 7;

因?yàn)槭莂ny類型侣诺,可以是數(shù)組,可以是對象氧秘,所以

  • 在任意值上訪問任何屬性都是允許的
let anyThing: any = 'hello';
console.log(anyThing.myName);
console.log(anyThing.myName.firstName);
  • 也允許調(diào)用任何方法:
let anyThing: any = 'Tom';
anyThing.setName('Jerry');
anyThing.setName('Jerry').sayHello();
anyThing.myName.setFirstName('Cat');

可以認(rèn)為年鸳,聲明一個(gè)變量為任意值之后,對它的任何操作丸相,返回的內(nèi)容的類型都是任意值搔确。

類型推論

如果沒有明確的指定類型,那么 TypeScript 會(huì)依照類型推論(Type Inference)的規(guī)則推斷出一個(gè)類型

在ts中灭忠,以下代碼雖然沒有指定類型膳算,但是會(huì)在編譯的時(shí)候報(bào)錯(cuò):

let myFavoriteNumber = 'seven';
myFavoriteNumber = 7;

// index.ts(2,1): error TS2322: Type 'number' is not assignable to type 'string'.

事實(shí)上,它等價(jià)于:

let myFavoriteNumber: string = 'seven';
myFavoriteNumber = 7;

TypeScript 會(huì)在沒有明確的指定類型的時(shí)候推測出一個(gè)類型更舞,這就是類型推論畦幢。

如果定義的時(shí)候沒有賦值,不管之后有沒有賦值缆蝉,都會(huì)被推斷成 any 類型而完全不被類型檢查宇葱,不會(huì)報(bào)錯(cuò)
let myFavoriteNumber;
myFavoriteNumber = 'seven';
myFavoriteNumber = 7;

tips:注意變量被推導(dǎo)成any類型的關(guān)鍵點(diǎn),在于我們定義一個(gè)變量之后刊头,有沒有立即賦值黍瞧。定義之后沒有賦值,以后就會(huì)定義為any類型原杂,如果定義之后印颤,第一次賦值是string,就會(huì)推導(dǎo)為string類型穿肄。

參考

TypeScript 入門教程

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末年局,一起剝皮案震驚了整個(gè)濱河市际看,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌矢否,老刑警劉巖仲闽,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異僵朗,居然都是意外死亡赖欣,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門验庙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來顶吮,“玉大人,你說我怎么就攤上這事粪薛°擦耍” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵汗菜,是天一觀的道長让禀。 經(jīng)常有香客問我,道長陨界,這世上最難降的妖魔是什么巡揍? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮菌瘪,結(jié)果婚禮上腮敌,老公的妹妹穿的比我還像新娘。我一直安慰自己俏扩,他們只是感情好糜工,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著录淡,像睡著了一般捌木。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上嫉戚,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天刨裆,我揣著相機(jī)與錄音,去河邊找鬼彬檀。 笑死帆啃,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的窍帝。 我是一名探鬼主播努潘,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了疯坤?” 一聲冷哼從身側(cè)響起报慕,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎贴膘,沒想到半個(gè)月后卖子,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體略号,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡刑峡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了玄柠。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片突梦。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖羽利,靈堂內(nèi)的尸體忽然破棺而出宫患,到底是詐尸還是另有隱情,我是刑警寧澤这弧,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布娃闲,位于F島的核電站,受9級(jí)特大地震影響匾浪,放射性物質(zhì)發(fā)生泄漏皇帮。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一蛋辈、第九天 我趴在偏房一處隱蔽的房頂上張望属拾。 院中可真熱鬧,春花似錦冷溶、人聲如沸渐白。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽纯衍。三九已至,卻和暖如春苗胀,著一層夾襖步出監(jiān)牢的瞬間襟诸,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來泰國打工柒巫, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留励堡,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓堡掏,卻偏偏與公主長得像应结,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344