亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

淺聊一下TypeScript中的4種類型守衛(wèi)

 更新時間:2023年08月25日 11:08:15   作者:思路大于開發(fā)  
類型守衛(wèi)是TypeScript中特有的用于在運行時檢查類型的方式,它顯式的將javascript代碼按類型劃分,從而確保了運行安全,下面我們就來簡單聊聊TypeScript中的4種類型守衛(wèi)吧

什么是守衛(wèi)?

守衛(wèi)是一種代碼安全性檢查,只在滿足某個指定條件時運行一段特定的邏輯,比如vite中的import.meta.hot

什么是類型守衛(wèi)?

類型守衛(wèi)是TypeScript中特有的用于在運行時檢查類型的方式,它顯式的將javascript代碼按類型劃分,從而確保了運行安全

為什么需要類型守衛(wèi)?

這可能要從一個聯(lián)合類型說起。如下,是筆者提出的一個可能不那么貼合的示例:有聯(lián)合類型Animal,它由DogSp組成,它們都有hobby屬性,但屬性的類型不同

type Dog = {
    hobby:'chishi'
}
type Sp = {
    hobby:()=>void;
}
type Animal = Dog | SP

現在你的代碼里要根據Animal去做一些事情,預期是Sp時執(zhí)行函數調用,是Dog輸出console提示。如果沒有守衛(wèi),則該需求無法實現,因為你無法確定subject到底是哪一種,執(zhí)行調用不符合Dog,執(zhí)行輸出不滿足Sp

如何守衛(wèi)?

TypeScript中,實現守衛(wèi)的方式有4種:in、instanceoftypeof和自定義

1.typeof

該關鍵字只能用于對基礎類型進行守衛(wèi),具體來說,是number、string、booleansymbol、function、undefined

function log(subject:number|string):string{
    if(typeof subject === 'number'){
        return `${subject+5}`
    }
    if(typeof subject === 'string'){
        return subject + '5'
    }
    return ''
}

但它無法解決我們前文舉例的Animal類型,因為typeof對對象只能識別到object,而對象下的屬性是什么仍然是一個黑盒

2.instanceof

對象類型的識別可以借助instanceof關鍵字,它通過檢查a是否是b的實例來確定a的可用范圍

3.in

當兩個類型是對象形式,但具有不同的獨有屬性時,可以使用in關鍵字來守衛(wèi)。如下,TypeScript會自動將其推斷為Dog類型

4.自定義

自定義類型保護是一種函數寫法,該函數返回truefalse,TypeScript會對返回值進行類型推斷

如下,當傳遞的subject中包含hobby時,'hobby' in subject的結果為true

function isDog(subject:any):subject is Dog{
    return 'hobby' in subject
}

true的結果會進一步被TypeScript推斷為Dog類型

到此這篇關于淺聊一下TypeScript中的4種類型守衛(wèi)的文章就介紹到這了,更多相關TypeScript類型守衛(wèi)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • xmlplus組件設計系列之按鈕(2)

    xmlplus組件設計系列之按鈕(2)

    xmlplus 是一個JavaScript框架,用于快速開發(fā)前后端項目。這篇文章主要介紹了xmlplus組件設計系列之按鈕,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • cocos creator Touch事件應用(觸控選擇多個子節(jié)點的實例)

    cocos creator Touch事件應用(觸控選擇多個子節(jié)點的實例)

    下面小編就為大家?guī)硪黄猚ocos creator Touch事件應用(觸控選擇多個子節(jié)點的實例)。小編覺得挺不錯的,現在就想給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • 解決layer.open后laydate失效的問題

    解決layer.open后laydate失效的問題

    今天小編就為大家分享一篇解決layer.open后laydate失效的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • js實現點擊生成隨機div

    js實現點擊生成隨機div

    這篇文章主要為大家詳細介紹了js實現點擊生成隨機div,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • open 動態(tài)修改img的onclick事件示例代碼

    open 動態(tài)修改img的onclick事件示例代碼

    動態(tài)修改img的onclick事件,使用open也可輕松做到,下面有個不錯的示例,需要的朋友可以參考下
    2013-11-11
  • JS從數組中隨機獲取一個值的常用寫法

    JS從數組中隨機獲取一個值的常用寫法

    這篇文章主要介紹了JS從數組中隨機獲取一個值的常用寫法,需要的朋友可以參考下
    2023-07-07
  • JavaScript indexOf()原理及使用方法詳解

    JavaScript indexOf()原理及使用方法詳解

    這篇文章主要介紹了JavaScript indexOf()原理及使用方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07
  • 深入淺析JavaScript中數據共享和數據傳遞

    深入淺析JavaScript中數據共享和數據傳遞

    這篇文章主要介紹了深入淺析JavaScript中數據共享和數據傳遞的相關資料,需要的朋友可以參考下
    2016-04-04
  • js實現可旋轉的立方體模型

    js實現可旋轉的立方體模型

    這里給大家分享的是通過js腳本來控制頁面中的正方體轉動特效,用戶可以點擊按鈕向右轉動,也可以向下轉動,結合自己的需求控制即可。效果非常棒,這里推薦給大家
    2016-10-10
  • 原生js圖片輪播效果實現代碼

    原生js圖片輪播效果實現代碼

    這篇文章主要為大家詳細介紹了基于原生js實現圖片輪播效果的具體代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10

最新評論