<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        TypeScript中的方法重載詳解

        來源:懂視網 責編:小采 時間:2020-11-27 21:58:46
        文檔

        TypeScript中的方法重載詳解

        TypeScript中的方法重載詳解:前言 方法重載(overload)在傳統的靜態類型語言中是很常見的。JavaScript 作為動態語言, 是沒有重載這一說的。一是它的參數沒有類型的區分,二是對參數個數也沒有檢查。雖然語言層面無法自動進行重載,但借助其動態的特性,我們可以在代碼中手動檢查入參的
        推薦度:
        導讀TypeScript中的方法重載詳解:前言 方法重載(overload)在傳統的靜態類型語言中是很常見的。JavaScript 作為動態語言, 是沒有重載這一說的。一是它的參數沒有類型的區分,二是對參數個數也沒有檢查。雖然語言層面無法自動進行重載,但借助其動態的特性,我們可以在代碼中手動檢查入參的

        前言

        方法重載(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[];

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

        相關資源

      1. TypeScript Handbook - Functions - Overloads
      2. Typescript method overloading
      3. 總結

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        TypeScript中的方法重載詳解

        TypeScript中的方法重載詳解:前言 方法重載(overload)在傳統的靜態類型語言中是很常見的。JavaScript 作為動態語言, 是沒有重載這一說的。一是它的參數沒有類型的區分,二是對參數個數也沒有檢查。雖然語言層面無法自動進行重載,但借助其動態的特性,我們可以在代碼中手動檢查入參的
        推薦度:
        標簽: 詳解 函數 的函數
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 无码人妻久久一区二区三区免费丨| a级毛片视频免费观看| 大学生高清一级毛片免费| 亚洲美女视频免费| 2020久久精品国产免费| 亚洲毛片免费观看| 91精品视频免费| 亚洲中文字幕久久精品无码A| 破了亲妺妺的处免费视频国产| 白白色免费在线视频| 亚洲性日韩精品一区二区三区| 久久久WWW免费人成精品| 国产亚洲精品xxx| 美丽的姑娘免费观看在线播放| 亚洲人成人77777网站不卡| 成人a视频片在线观看免费| 免费播放美女一级毛片| 久久久久亚洲AV综合波多野结衣 | 国产偷国产偷亚洲清高APP| 又粗又大又硬又爽的免费视频| 乱淫片免费影院观看| 老司机亚洲精品影院无码 | aⅴ在线免费观看| 亚洲国产成人精品无码区花野真一 | 亚洲综合综合在线| 免费观看a级毛片| 色哟哟国产精品免费观看| 国产成人综合亚洲AV第一页 | 亚洲国产精品久久久久秋霞影院| 国产免费AV片在线播放唯爱网| 激情小说亚洲图片| 亚洲va无码专区国产乱码| 男男AV纯肉无码免费播放无码| 男人j进女人p免费视频| 久久亚洲春色中文字幕久久久| 好大好深好猛好爽视频免费| 91成人免费观看在线观看| 456亚洲人成影院在线观| 亚洲中文字幕日产乱码高清app| 又大又硬又爽又粗又快的视频免费| 99亚洲男女激情在线观看|