ts泛型使用舉例

官方文檔地址:https://www.typescriptlang.org/docs/handbook/generics.html
中文文檔:https://www.tslang.cn/docs/handbook/generics.html

什么是泛型呢?

泛型随闪,簡(jiǎn)單來(lái)說(shuō)就是類型變量舆瘪。在ts中存在類型忌警,類型如number兜畸、string含思、boolean等蔗衡,泛型就是使用一個(gè)類型變量來(lái)表示一種類型再榄,類型值通常是在使用的時(shí)候才會(huì)設(shè)置。泛型的使用場(chǎng)景非常多襟诸,可以在函數(shù)瓦堵、類甚至interface中使用。

如:我們編寫(xiě)一個(gè)類似lodash.find的方法

function find<T>(items: T[], callback: (item: T, index: number) => boolean): T | undefined {
  for (let i = 0, length = items.length; i < length; i++) {
    if (callback(items[i], i)) {
      return items[i]
    }
  }
}

const items = [{ a: 1 }, { a: 2 }, { a: 4 }, null ]
const result = find(items, (item, index) => item.a === 2)

首先<T>是給函數(shù)聲明了一個(gè)類型變量T歌亲,后面要求items是一個(gè)T類型的數(shù)組菇用,然后后面的callback函數(shù)的參數(shù)item是一個(gè)T類型的變量,index為數(shù)字陷揪,然后callback返回boolean類型結(jié)果惋鸥,整個(gè)find函數(shù)返回T類型結(jié)果或者undefined

如上,我們就能準(zhǔn)確定義函數(shù)的每一個(gè)參數(shù)了悍缠,參數(shù)與參數(shù)卦绣,參數(shù)與返回結(jié)果之間就形成了約束關(guān)系

在使用的時(shí)候,由于定義了數(shù)組的元素必須是同一種類型飞蚓,所以編譯時(shí)就會(huì)提示錯(cuò)誤

如果沒(méi)有使用泛型滤港,我們就只能使用any定義每一個(gè)參數(shù)了,如下

function find(items: any[], callback: (item: any, index: number) => boolean): any {
  for (let i = 0, length = items.length; i < length; i++) {
    if (callback(items[i], i)) {
      return items[i]
    }
  }
}

const items = [{ a: 1 }, { a: 2 }, { a: 4 }, null ]
const result = find(items, (item, index) => item.a === 2)

以上代碼趴拧,ts編譯是可以通過(guò)的溅漾,但很明顯是非常不嚴(yán)謹(jǐn)?shù)模瑢?duì)于items的定義就可以很寬泛了著榴,然而使用泛型的時(shí)候就限制了只能是某一種類型的數(shù)組樟凄,這樣就可以把可能出現(xiàn)的錯(cuò)誤在開(kāi)發(fā)時(shí)就找出來(lái)

簡(jiǎn)單總結(jié)心得,有不正確的地方還請(qǐng)指正兄渺。


泥腿子前端的眼淚

歡迎關(guān)注我: https://github.com/nashaofu

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子挂谍,更是在濱河造成了極大的恐慌叔壤,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,402評(píng)論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件口叙,死亡現(xiàn)場(chǎng)離奇詭異炼绘,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)妄田,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門俺亮,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人疟呐,你說(shuō)我怎么就攤上這事脚曾。” “怎么了启具?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,483評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵本讥,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我鲁冯,道長(zhǎng)拷沸,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,165評(píng)論 1 292
  • 正文 為了忘掉前任薯演,我火速辦了婚禮撞芍,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘跨扮。我一直安慰自己序无,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布好港。 她就那樣靜靜地躺著愉镰,像睡著了一般。 火紅的嫁衣襯著肌膚如雪钧汹。 梳的紋絲不亂的頭發(fā)上丈探,一...
    開(kāi)封第一講書(shū)人閱讀 51,146評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音拔莱,去河邊找鬼碗降。 笑死,一個(gè)胖子當(dāng)著我的面吹牛塘秦,可吹牛的內(nèi)容都是我干的讼渊。 我是一名探鬼主播,決...
    沈念sama閱讀 40,032評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼尊剔,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼爪幻!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,896評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤挨稿,失蹤者是張志新(化名)和其女友劉穎仇轻,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體奶甘,經(jīng)...
    沈念sama閱讀 45,311評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡篷店,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了臭家。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片疲陕。...
    茶點(diǎn)故事閱讀 39,696評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖钉赁,靈堂內(nèi)的尸體忽然破棺而出蹄殃,到底是詐尸還是另有隱情,我是刑警寧澤橄霉,帶...
    沈念sama閱讀 35,413評(píng)論 5 343
  • 正文 年R本政府宣布窃爷,位于F島的核電站,受9級(jí)特大地震影響姓蜂,放射性物質(zhì)發(fā)生泄漏按厘。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評(píng)論 3 325
  • 文/蒙蒙 一钱慢、第九天 我趴在偏房一處隱蔽的房頂上張望逮京。 院中可真熱鬧,春花似錦束莫、人聲如沸懒棉。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至饿敲,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間怀各,已是汗流浹背倔韭。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,815評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工瓢对, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留寿酌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,698評(píng)論 2 368
  • 正文 我出身青樓硕蛹,卻偏偏與公主長(zhǎng)得像醇疼,于是被迫代替她去往敵國(guó)和親硕并。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評(píng)論 2 353

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