淺聊一下TypeScript中的4種類型守衛(wèi)
什么是守衛(wèi)?
守衛(wèi)是一種代碼安全性檢查,只在滿足某個(gè)指定條件時(shí)運(yùn)行一段特定的邏輯,比如vite中的import.meta.hot
什么是類型守衛(wèi)?
類型守衛(wèi)是TypeScript中特有的用于在運(yùn)行時(shí)檢查類型的方式,它顯式的將javascript代碼按類型劃分,從而確保了運(yùn)行安全
為什么需要類型守衛(wèi)?
這可能要從一個(gè)聯(lián)合類型說起。如下,是筆者提出的一個(gè)可能不那么貼合的示例:有聯(lián)合類型Animal,它由Dog和Sp組成,它們都有hobby屬性,但屬性的類型不同
type Dog = {
hobby:'chishi'
}
type Sp = {
hobby:()=>void;
}
type Animal = Dog | SP現(xiàn)在你的代碼里要根據(jù)Animal去做一些事情,預(yù)期是Sp時(shí)執(zhí)行函數(shù)調(diào)用,是Dog輸出console提示。如果沒有守衛(wèi),則該需求無法實(shí)現(xiàn),因?yàn)槟銦o法確定subject到底是哪一種,執(zhí)行調(diào)用不符合Dog,執(zhí)行輸出不滿足Sp

如何守衛(wèi)?
在TypeScript中,實(shí)現(xiàn)守衛(wèi)的方式有4種:in、instanceof、typeof和自定義
1.typeof
該關(guān)鍵字只能用于對(duì)基礎(chǔ)類型進(jì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類型,因?yàn)?code>typeof對(duì)對(duì)象只能識(shí)別到object,而對(duì)象下的屬性是什么仍然是一個(gè)黑盒

2.instanceof
對(duì)象類型的識(shí)別可以借助instanceof關(guān)鍵字,它通過檢查a是否是b的實(shí)例來確定a的可用范圍

3.in
當(dāng)兩個(gè)類型是對(duì)象形式,但具有不同的獨(dú)有屬性時(shí),可以使用in關(guān)鍵字來守衛(wèi)。如下,TypeScript會(huì)自動(dòng)將其推斷為Dog類型

4.自定義
自定義類型保護(hù)是一種函數(shù)寫法,該函數(shù)返回true或false,TypeScript會(huì)對(duì)返回值進(jìn)行類型推斷
如下,當(dāng)傳遞的subject中包含hobby時(shí),'hobby' in subject的結(jié)果為true
function isDog(subject:any):subject is Dog{
return 'hobby' in subject
}true的結(jié)果會(huì)進(jìn)一步被TypeScript推斷為Dog類型

到此這篇關(guān)于淺聊一下TypeScript中的4種類型守衛(wèi)的文章就介紹到這了,更多相關(guān)TypeScript類型守衛(wèi)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
cocos creator Touch事件應(yīng)用(觸控選擇多個(gè)子節(jié)點(diǎn)的實(shí)例)
下面小編就為大家?guī)硪黄猚ocos creator Touch事件應(yīng)用(觸控選擇多個(gè)子節(jié)點(diǎn)的實(shí)例)。小編覺得挺不錯(cuò)的,現(xiàn)在就想給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09
js實(shí)現(xiàn)點(diǎn)擊生成隨機(jī)div
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)點(diǎn)擊生成隨機(jī)div,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-01-01
open 動(dòng)態(tài)修改img的onclick事件示例代碼
動(dòng)態(tài)修改img的onclick事件,使用open也可輕松做到,下面有個(gè)不錯(cuò)的示例,需要的朋友可以參考下2013-11-11
JS從數(shù)組中隨機(jī)獲取一個(gè)值的常用寫法
這篇文章主要介紹了JS從數(shù)組中隨機(jī)獲取一個(gè)值的常用寫法,需要的朋友可以參考下2023-07-07
深入淺析JavaScript中數(shù)據(jù)共享和數(shù)據(jù)傳遞
這篇文章主要介紹了深入淺析JavaScript中數(shù)據(jù)共享和數(shù)據(jù)傳遞的相關(guān)資料,需要的朋友可以參考下2016-04-04
js實(shí)現(xiàn)可旋轉(zhuǎn)的立方體模型
這里給大家分享的是通過js腳本來控制頁面中的正方體轉(zhuǎn)動(dòng)特效,用戶可以點(diǎn)擊按鈕向右轉(zhuǎn)動(dòng),也可以向下轉(zhuǎn)動(dòng),結(jié)合自己的需求控制即可。效果非常棒,這里推薦給大家2016-10-10

