淺聊一下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
,它由Dog
和Sp
組成,它們都有hobby
屬性,但屬性的類型不同
type Dog = { hobby:'chishi' } type Sp = { hobby:()=>void; } type Animal = Dog | SP
現(xiàn)在你的代碼里要根據(jù)Animal
去做一些事情,預期是Sp
時執(zhí)行函數(shù)調(diào)用,是Dog
輸出console
提示。如果沒有守衛(wèi),則該需求無法實現(xiàn),因為你無法確定subject
到底是哪一種,執(zhí)行調(diào)用不符合Dog
,執(zhí)行輸出不滿足Sp
如何守衛(wèi)?
在TypeScript
中,實現(xiàn)守衛(wèi)的方式有4種:in
、instanceof
、typeof
和自定義
1.typeof
該關(guān)鍵字只能用于對基礎類型進行守衛(wèi),具體來說,是number
、string
、boolean
、symbol
、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
關(guān)鍵字,它通過檢查a是否是b的實例來確定a的可用范圍
3.in
當兩個類型是對象形式,但具有不同的獨有屬性時,可以使用in
關(guān)鍵字來守衛(wèi)。如下,TypeScript
會自動將其推斷為Dog
類型
4.自定義
自定義類型保護是一種函數(shù)寫法,該函數(shù)返回true
或false
,TypeScript
會對返回值進行類型推斷
如下,當傳遞的subject
中包含hobby
時,'hobby' in subject
的結(jié)果為true
function isDog(subject:any):subject is Dog{ return 'hobby' in subject }
true
的結(jié)果會進一步被TypeScript
推斷為Dog類型
到此這篇關(guān)于淺聊一下TypeScript中的4種類型守衛(wèi)的文章就介紹到這了,更多相關(guān)TypeScript類型守衛(wèi)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
cocos creator Touch事件應用(觸控選擇多個子節(jié)點的實例)
下面小編就為大家?guī)硪黄猚ocos creator Touch事件應用(觸控選擇多個子節(jié)點的實例)。小編覺得挺不錯的,現(xiàn)在就想給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09open 動態(tài)修改img的onclick事件示例代碼
動態(tài)修改img的onclick事件,使用open也可輕松做到,下面有個不錯的示例,需要的朋友可以參考下2013-11-11深入淺析JavaScript中數(shù)據(jù)共享和數(shù)據(jù)傳遞
這篇文章主要介紹了深入淺析JavaScript中數(shù)據(jù)共享和數(shù)據(jù)傳遞的相關(guān)資料,需要的朋友可以參考下2016-04-04