亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

TypeScript中的方法重載詳解

2019-11-19 11:47:57
字體:
來源:轉載
供稿:網友

前言

方法重載(overload)在傳統的靜態類型語言中是很常見的。JavaScript 作為動態語言, 是沒有重載這一說的。一是它的參數沒有類型的區分,二是對參數個數也沒有檢查。雖然語言層面無法自動進行重載,但借助其動態的特性,我們可以在代碼中手動檢查入參的類型,或者通過 arguments 獲取到參數個數,從而實現根據不同的入參做不同的操作。

比如有一個獲取聊天消息的方法,根據傳入的參數從數組中查找數據。如果入參為數字,則認為是 id,然后從數據源中找對應 id 的數據并返回,否則當成類型,返回這一類型的消息。

function getMessage(query) { if (typeof query === "nunber") { return data.find(message => message.id === query); } else { return data.filter(message => message.type === query); }}

TypeScript 中,假如我們的消息數據為如下結構:

type MessageType = "string" | "image" | "audio";type Message = { id: number; type: MessageType; content: string;};

上面獲取數據的方法等價于:

function getMessage( query: number | MessageType): Message[] | Message | undefined { if (typeof query === "number") { return data.find(message => message.id === query); } else { return data.filter(message => message.type === query); }}

這樣做一是類型書寫上比較丑陋,二是沒有發揮出 TypeScript 類型檢查的優勢,這里我們是可以根據入參的類型明確知道返回的類型的,即如果傳入的是 id,返回的是單個數據或undefined,如果是根據類型查找,返回的是數組。而現在調用方法后,得到的類型太過寬泛,這和使用 any 做為返回沒多大差別。

函數返回類型不夠緊湊

因為類型的不明朗,返回的結果都不能直接操作,需要進行類型轉換后才能繼續。

const result1 = getMessage("audio");/** 不能直接對 result1 調用數組方法 */console.log((result1 as Message[]).length);const result2 = getMessage(1);if (result2) { /** 不能對 result2 直接訪問消息對象中的屬性 */ console.log((result2 as Message).content);}

重載的實現

這時候可通過提供多個函數類型的聲明來解決上面的問題,最后得到的結果就是間接實現了函數的重載。當然這個重載只是 TypeScript 編譯時的。

function getMessage(id: number): Message | undefined;function getMessage(type: MessageType): Message[];function getMessage(query: any): any { if (typeof query === "number") {  return data.find(message => message.id === query); } else {  return data.filter(message => message.type === query); }}

這樣改造后,我們在調用的時候直接就會有重載的提示。

實現 TypeScript 的重載后調用時的自動提示

并且得到的結果類型是重載方法中指定的入參與返回的組合,在對結果進行使用時,無須再進行類型轉換。

const result1 = getMessage("audio");/** ✅ 無須類型轉換 */console.log(result1.length);const result2 = getMessage(1);if (result2) { /** ✅ 無須類型轉換 */ console.log(result2.content);}

這里需要理解的是,上面添加的函數類型僅作為 TypeScript 在編譯時使用的,它不是真的實現像傳統靜態類型語言那樣的重載,也不會改變編譯后代碼的輸出。實際運行時仍然是不帶重載的 JavaScript 版本。

編譯后的代碼

但這一點也不影響我們在 TypeScript 中使用這種假的重載。

可選參數

另一個 TypeScript 重載的場景。還是上面獲取消息數據的方法,因為根據類型查找消息時,會返回同類型消息的一個數組。此時我們想加一個參數實現只返回結果中前幾個數據,那么可以很方便地進行如下的改造:

function getMessage(id: number): Message | undefined;+function getMessage(type: MessageType, count?: number): Message[];+function getMessage(query: any, count = 10): any { if (typeof query === "number") {  return data.find(message => message.id === query); } else {+  return data.filter(message => message.type === query).splice(0, count); }}

通過重載,這個新增的參數很容易實現只針對入參 MessageType 時,這樣如果我們有如下的調用,會得到編譯時的報錯:

/** 🚨 Argument of type '1' is not assignable to parameter of type 'MessageType' */getMessage(1,10);

而非重載的版本是享受不到上面提到的類型優勢的。

function getMessage( query: number | MessageType, count = 10): Message[] | Message | undefined { if (typeof query === "number") {  return data.find(message => message.id === query); } else {  return data.filter(message => message.type === query).splice(0, count); }}/** ✅ ojbk, 不錯報 */getMessage(1, 10);

重載過程

TypeScript 重載的過程是,拿傳入的參數和重載的方法簽名列表中由上往下逐個匹配,直到找到一個完全匹配的函數簽名,否則報錯。所以推薦的做法是將簽名更加具體的重載放上面,不那么具體的放后面。

/** ✅*/function getMessage(type: MessageType, count?: number): Message[];function getMessage(id: number): Message | undefined;/** 🚨*/function getMessage(id: number): Message | undefined;function getMessage(type: MessageType, count?: number): Message[];

像上面示例中正確做法這樣,如果說入參個數只有一個,那可以直接跳過第一個函數簽名,無須做入參類型的判斷。

相關資源

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97在线免费视频| 久久97久久97精品免视看| 欧美精品精品精品精品免费| 久久久久国产一区二区三区| 亚洲美女性生活视频| 91在线视频九色| 色老头一区二区三区在线观看| 精品久久久久久久中文字幕| 成人av.网址在线网站| 国产精品十八以下禁看| 在线观看亚洲视频| 日本午夜人人精品| 精品国产91久久久久久| 国产一区二区丝袜高跟鞋图片| 久久国产精品首页| 色与欲影视天天看综合网| 精品美女久久久久久免费| 成人精品在线观看| 国产亚洲精品久久久久动| 国产日韩欧美视频| 在线播放精品一区二区三区| 亚洲国产精品电影在线观看| 久久久黄色av| 一区二区欧美久久| 欧美精品第一页在线播放| 国产专区欧美专区| 久久久久久久久久久久av| 91嫩草在线视频| 91a在线视频| 久久精品视频亚洲| 国产免费一区二区三区在线能观看| 高跟丝袜一区二区三区| 日韩美女av在线| 日韩精品高清在线观看| 欧美日韩美女视频| 欧美日韩国产一区二区| 欧美成人三级视频网站| 成人h片在线播放免费网站| 国产成人久久精品| 高清一区二区三区日本久| 亚洲欧美精品中文字幕在线| 在线观看欧美日韩| 亚洲xxxxx性| 日本视频久久久| 国产99在线|中文| 久久伊人精品一区二区三区| 97精品久久久中文字幕免费| 亚洲精品一区中文字幕乱码| 精品中文视频在线| 亚洲色图校园春色| 亚洲欧美激情在线视频| 欧美韩日一区二区| 欧洲美女免费图片一区| 成人美女av在线直播| 中文字幕日韩专区| 91精品综合久久久久久五月天| 亚洲精品自拍偷拍| 欧美性色xo影院| 最近2019中文字幕大全第二页| 欧美精品久久久久| 亚洲激情国产精品| 亚洲女同性videos| 中文字幕av一区二区三区谷原希美| 国产精品扒开腿做爽爽爽的视频| 亚洲最大激情中文字幕| 久久久久久久久久久成人| 欧美电影免费播放| 美女av一区二区| 亚洲天堂视频在线观看| 欧美在线视频观看免费网站| 欧美区二区三区| 欧美高清在线播放| 中文字幕一区二区三区电影| 上原亚衣av一区二区三区| 欧美激情三级免费| 2025国产精品视频| 日本午夜精品理论片a级appf发布| 91久久国产综合久久91精品网站| 欧美麻豆久久久久久中文| 91色中文字幕| 亚洲综合日韩中文字幕v在线| 91在线免费网站| 一区二区福利视频| 8050国产精品久久久久久| 欧美日韩久久久久| 欧美劲爆第一页| 欧美疯狂做受xxxx高潮| 久久69精品久久久久久久电影好| 日韩午夜在线视频| 精品久久久久久久久中文字幕| 日韩精品一二三四区| 欧美日韩xxx| 日韩av影院在线观看| 欧美裸体xxxxx| 日韩大陆毛片av| 欧美香蕉大胸在线视频观看| 日韩精品视频在线观看网址| 91精品在线影院| 亚洲欧洲日产国码av系列天堂| 亚洲精品久久久久国产| 国产亚洲日本欧美韩国| 久久九九全国免费精品观看| 国产不卡在线观看| 久久久成人av| 国产成人精品优优av| 亚洲国产精品一区二区久| 国产精品永久在线| 国产精品成人一区二区三区吃奶| 5252色成人免费视频| 日韩电视剧在线观看免费网站| 欧美性生活大片免费观看网址| 日韩午夜在线视频| 亚洲色图狂野欧美| 国产精品久久久久久久电影| 国产91精品久久久久久| 久久成人国产精品| 青草青草久热精品视频在线网站| 黑人极品videos精品欧美裸| 精品福利在线视频| 激情成人中文字幕| 久久99久国产精品黄毛片入口| 亚洲成年网站在线观看| 久久国产精品首页| 一区二区三区国产视频| 草民午夜欧美限制a级福利片| 久久精品色欧美aⅴ一区二区| 亚洲午夜女主播在线直播| 国产欧美精品久久久| 国产成人极品视频| 1769国内精品视频在线播放| 伦伦影院午夜日韩欧美限制| 久久综合久久美利坚合众国| 国产日本欧美一区二区三区在线| 久久琪琪电影院| 欧美成人在线免费视频| 亚洲剧情一区二区| 亚洲石原莉奈一区二区在线观看| 成人亚洲综合色就1024| 国模精品视频一区二区三区| 亚洲香蕉伊综合在人在线视看| 国产亚洲精品久久久优势| 69精品小视频| 国产精品免费久久久久久| 日韩精品视频观看| 亚洲欧美日韩国产中文专区| 日韩视频免费大全中文字幕| www亚洲欧美| 色天天综合狠狠色| 51精品国产黑色丝袜高跟鞋| 在线精品国产欧美| 久热精品视频在线免费观看| 亚洲另类图片色| 欧美电影免费观看网站| 亚洲一区二区免费| 亲爱的老师9免费观看全集电视剧| 97在线视频精品| 欧美最猛性xxxxx免费| 精品日韩中文字幕| 欧美视频第一页| 国产精品香蕉av| 欧日韩不卡在线视频| 亚洲欧美综合区自拍另类| 欧美又大又粗又长| 成人妇女免费播放久久久|