摘要:導(dǎo)航第一課體驗第二課基礎(chǔ)類型和入門高級類型第三課泛型第四課解讀高級類型很重要這一節(jié)很重要可以說是的最核心部分這一節(jié)學(xué)完其實就可以開始用寫代碼了想想中的再看看標(biāo)題中的類型字所以請大家務(wù)必認(rèn)真什么是入門高級類型因為高級類型的內(nèi)容比較多但是有些基
導(dǎo)航
第一課, 體驗typescript
第二課, 基礎(chǔ)類型和入門高級類型
第三課, 泛型
第四課, 解讀高級類型
很重要這一節(jié)很重要, 可以說是ts的最核心部分, 這一節(jié)學(xué)完其實就可以開始用ts寫代碼了, 想想typescript中的type, 再看看標(biāo)題中的"類型"2字, 所以請大家務(wù)必認(rèn)真.
什么是入門高級類型因為高級類型的內(nèi)容比較多, 但是有些基礎(chǔ)類型的知識點還必須要用到高級類型的知識講解才連貫, 所以本節(jié)課把最常用的高級類型提前講解一下, 比如接口/聯(lián)合類型/交叉類型.
基礎(chǔ)類型ts中基礎(chǔ)類型有如下幾種:boolean / number / string / object / 數(shù)組 / 元組 / 枚舉 / any / undefined / null / void / never, 下面我們一一舉例學(xué)習(xí):
字面量介紹類型前,有一個前置知識點就是字面量, 字面量的意思就是直接聲明, 而非new關(guān)鍵詞實例化出來的數(shù)據(jù):
// 字面量 const n:number = 123; const s:string = "456"; const o:object = {a:1,b:"2"}; // 非字面量 const n:Number = new Number(123); const s:String = new String("456"); const o:Object = new Object({a:1,b:"2"});
通過上面的例子, 大家應(yīng)該看明白為什么ts中有些類型的開頭字母是小寫的了吧. 這是因為ts中用小寫字母開頭的類型代表字面量, 大寫的是用來表示通過new實例化的數(shù)據(jù).
boolean布爾類型, 取值只有true / false
const IS_MOBILE:boolean = true; const IS_TABLE:boolean = false;number
數(shù)字類型, 整數(shù)/小數(shù)都包括, 同時支持2/8/10/16進制字面量.
let decLiteral: number = 6; let hexLiteral: number = 0xf00d; let binaryLiteral: number = 0b1010; let octalLiteral: number = 0o744;string
字符串類型
let s1:string = "hello world!"; let s2:string = "hello ${name}`;數(shù)組
數(shù)組有2種表示方式:
第1種, 通過在指定類型后面增加[], 表示該數(shù)組內(nèi)的元素都是該指定類型:
let numbers:number[] = [1,2,3,4,5]; // number|string代表聯(lián)合類型, 下面的高級類型中會講 let numbers:(number|string)[] = [1,2,3,4,"5"];
第2種, 通過泛型表示, Array<元素類型>, 泛型會在后面課講解, 先做了解即可:
let numbers:Array元組(Tuple)= [1,2,3,4,5];
元組類型表示一個已知元素數(shù)量和類型的數(shù)組, 各元素的類型不必相同:
let list1:[number, string] = [1, "2", 3]; // 錯誤, 數(shù)量不對, 元組中只聲明有2個元素 let list2:[number, string] = [1, 2]; // 錯誤, 第二個元素類型不對, 應(yīng)該是字符串"2" let list3:[number, string] = ["1", 2]; // 錯誤, 2個元素的類型顛倒了 let list4:[number, string] = [1, "2"]; // 正確枚舉(enum)
枚舉是ts中有而js中沒有的類型, 編譯后會被轉(zhuǎn)化成對象, 默認(rèn)元素的值從1開始, 如下面的Color.Red的值為1, 以此類推Color.Green為2, Color.Blue為3:
enum Color {Red, Green, Blue} // 等價 enum Color {Red=1, Green=2, Blue=3}
當(dāng)然也可以自己手動賦值:
enum Color {Red=1, Green=2, Blue=4}
并且我們可以反向通過值得到他的鍵值:
enum Color {Red=1, Green=2, Blue=4} Color[2] === "Green" // true
看下編譯成js后的枚舉代碼, 你就明白為什么可以反向得到鍵值:
var Color; (function (Color) { Color[Color["Red"] = 0] = "Red"; Color[Color["Green"] = 1] = "Green"; Color[Color["Blue"] = 2] = "Blue"; })(Color || (Color = {})); // Color的值為: {0: "Red", 1: "Green", 2: "Blue", Red: 0, Green: 1, Blue: 2}any(任意類型)
any代表任意類型, 也就是說, 如果你不清楚變量是什么類型, 就可以用any進行標(biāo)記, 比如引入一些比較老的js庫, 沒有聲明類型, 使用的時候就可以標(biāo)記為any類型, 這樣ts就不會提示錯誤了. 當(dāng)然不能所有的地方都用any, 那樣ts就沒有使用的意義了.
let obj:any = {}; // ts自己推導(dǎo)不出forEach中給obj增加了"a"和"b"字段. ["a", "b"].forEach(letter=>{ obj[letter] = letter; }); // 但是因為標(biāo)記了any, 所以ts認(rèn)為a可能存在 obj.a = 123void
void的意義和any相反, 表示不是任何類型, 一般出現(xiàn)在函數(shù)中, 用來標(biāo)記函數(shù)沒有返回值:
function abc(n:number):void{ console.log(n); }
void類型對應(yīng)2個值, 一個是undefined,一個null:
const n1:void = undefined; const n2:void = null;null 和 undefined
默認(rèn)情況下null和undefined是所有類型的子類型, 比如:
const n1:null = 123; const n2:undefined = "123";
注意: 這是因為默認(rèn)情況下的編譯選項strictNullChecks為false, 但是為了避免一些奇怪的問題出現(xiàn), 我還是建議大家設(shè)置為true(編譯選項設(shè)置的內(nèi)容, 會在后面的課程講解), 請用精準(zhǔn)的類型去標(biāo)注.
如果一個變量的值確實需要是null或者undefined, 可以像下面這么用, ts會自動根據(jù)if/else推導(dǎo)出正確類型:
// 這是"聯(lián)合類型", 在"高級類型"中會有詳細(xì)介紹, 表示n可能是undefined也可能是number let num: undefined|number; if(Math.random()>0.5) num = 1; if(undefined !== num) { num++; }never
never表示不可達(dá), 用文字還真不好描述, 主要使用在throw的情況下:
function error():never{ throw "錯了!"; }object
object表示非原始類型, 也就是除number/ ss/ boolean/ symbol/ null/ undefined之外的類型:
let o1:object = []; let o2:object = {a:1,b:2};
但是, 我們實際上基本不用object類型的, 因為他標(biāo)注的非常不具體, 一般都用接口來標(biāo)注更具體的對象類型, 請繼續(xù)看下面的接口的內(nèi)容.
高級類型入門通過基礎(chǔ)類型組合而來的, 我們可以叫他高級類型. 包含: 交叉類型 / 聯(lián)合類型 / 接口等等, 當(dāng)然不止他們3個, 為了不讓本節(jié)課太長造成讀者疲勞, 本節(jié)只先講這3個, 不過不要著急, 下節(jié)課會完結(jié)高級類型.
接口(interface)一種定義復(fù)雜類型的格式, 比如我們用對象格式存儲一篇文章, 那么就可以用接口定義文章的類型:
interface Article { title: stirng; count: number; content:string; fromSite: string; } const article: Article = { title: "為vue3學(xué)點typescript(2), 類型", count: 9999, content: "xxx...", fromSite: "baidu.com" }
在這種情況下,當(dāng)我們給article賦值的時候, 如果任何一個字段沒有被賦值或者字段對應(yīng)的數(shù)據(jù)類型不對, ts都會提示錯誤, 這樣就保證了我們寫代碼不會出現(xiàn)上述的小錯誤.
非必填(?)還是上面的例子, fromSite的意思是文章來自那個網(wǎng)站,如果文章都是原創(chuàng)的, 該字段就不會有值, 但是如果我們不傳又會提示錯誤, 怎么辦?
這時候就需要標(biāo)記fromSite字段為非必填, 用"?"標(biāo)記:
interface Article { title: stirng; count: number; content:string; fromSite?: string; // 非必填 } // 不會報錯 const article: Article = { title: "為vue3學(xué)點typescript(2), 類型", count: 9999, content: "xxx...", }用接口定義函數(shù)
接口不僅可以定義對象, 還可以定義函數(shù):
// 聲明接口 interface Core { (n:number, s:string):[number,string] } // 聲明函數(shù)遵循接口定義 const core:Core = (a,b)=>{ return [a,b]; }用接口定義類
先簡單看下如何給類定義接口, 后面的課程具體講類:
// 定義 interface Animate { head:number; body:number; foot:number; eat(food:string):void; say(word:string):string; } // implements class Dog implements Animate{ head=1; body=1; foot=1; eat(food){ console.log(food); } say(word){ return word; } }交叉類型(&)
交叉類型是將多個類型合并為一個類型, 表示"并且"的關(guān)系,用&連接多個類型, 常用于對象合并:
interface A {a:number}; interface B {b:string}; const a:A = {a:1}; const b:B = {b:"1"}; const ab:A&B = {...a,...b};聯(lián)合類型(|)
交叉類型也是將多個類型合并為一個類型, 表示"或"的關(guān)系,用|連接多個類型:
function setWidth(el: HTMLElement, width: string | number) { el.style.width = "number" === typeof width ? `${width}px` : width; }
注意: 我這里標(biāo)記了el為HTMLElement, 可以在typescript的倉庫看到ts還定義了很多元素, 請自行瀏覽(不用背, 用的時候現(xiàn)查),
https://github.com/microsoft/...
如果您看完了上面的所有知識點, 你就可以開始動手造輪子練習(xí)了, 加油. 下面是我用ts造的輪子, 如果喜歡請幫忙點下star, 謝謝.
手勢庫: https://github.com/any86/any-...
命令式調(diào)用vue組件: https://github.com/any86/vue-...
工作中常用的一些代碼片段: https://github.com/any86/usef...
一個mini的事件管理器: https://github.com/any86/any-...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/105244.html
摘要:更新啦第一課體驗第二課基礎(chǔ)類型和入門高級類型第三課泛型第四課解讀高級類型要來了看了的視頻特別興奮要來了是用開發(fā)的我揣測在的帶領(lǐng)下會成為主流呢要不先學(xué)點年最酷的前端技術(shù)我是年初開始使用的自從開始用上了就喜歡上了真的愛不釋手最愛他幾點很多小錯誤 更新啦 第一課, 體驗typescript 第二課, 基礎(chǔ)類型和入門高級類型 第三課, 泛型 第四課, 解讀高級類型 vue3要來了 看了vue ...
摘要:往期第一課體驗第二課基礎(chǔ)類型和入門高級類型第三課泛型第四課解讀高級類型插一課本來打算接著上節(jié)課把高級類型都講完但是寫著寫著我發(fā)現(xiàn)高級類型中有很多地方都需要泛型的知識那么先插一節(jié)泛型什么是類型變量和泛型變量的概念我們都知道可以表示任意數(shù)據(jù)類型 往期 第一課, 體驗typescript 第二課, 基礎(chǔ)類型和入門高級類型 第三課, 泛型 第四課, 解讀高級類型 插一課 本來打算接著上節(jié)課, ...
摘要:往期目錄第一課體驗第二課基礎(chǔ)類型和入門高級類型第三課什么是泛型第四課解讀高級類型第五課什么是命名空間什么時候要用命名空間如果你發(fā)現(xiàn)自己寫的功能函數(shù)類接口等越來越多你想對他們進行分組管理就可以用命名空間下面先用類舉例仔細(xì)看你會發(fā)現(xiàn)下還有在這里 往期目錄 第一課, 體驗typescript 第二課, 基礎(chǔ)類型和入門高級類型 第三課, 什么是泛型? 第四課, 解讀高級類型 第五課, 什么是命...
摘要:直達(dá)第一課體驗第二課基礎(chǔ)類型和入門高級類型第三課泛型第四課解讀高級類型第五課什么是命名空間回顧第二課的時候為了更好的講解基礎(chǔ)類型所以我們講解了一部分高級類型比如接口聯(lián)合類型交叉類型本節(jié)課我會把剩余高級類型都講完知識點摘要本節(jié)課主要關(guān)鍵詞為自 直達(dá) 第一課, 體驗typescript 第二課, 基礎(chǔ)類型和入門高級類型 第三課, 泛型 第四課, 解讀高級類型 第五課, 什么是命名空間(na...
閱讀 1760·2021-11-25 09:43
閱讀 1797·2021-11-24 10:41
閱讀 3114·2021-09-27 13:36
閱讀 820·2019-08-30 15:53
閱讀 3578·2019-08-30 15:44
閱讀 872·2019-08-30 14:03
閱讀 2583·2019-08-29 16:38
閱讀 1007·2019-08-29 13:23