国产性猛交xx乱_性色国产成人久久久精品_亚洲成年人av_亚洲av片不卡无码久久_日本精品一二三_久久免费精品国产_欧美成人精品一区二区综合免费_无码人妻丰满熟妇区毛片蜜桃精品_四虎永久免费影院_国产一区二区三区四区在线

【TypeScript】TS類型守衛(wèi)(六)

2023-1-13    前端達(dá)人

專欄介紹

TypeScript從入門到實踐專欄是博主在學(xué)習(xí)和工作過程中的總結(jié),實用性非常強,歡迎訂閱哦,學(xué)會TS不迷路。

TS系列 標(biāo)題
基礎(chǔ)篇 TS入門(一)
基礎(chǔ)篇
TS類型聲明(二)
基礎(chǔ)篇 TS接口類型(三)
基礎(chǔ)篇 TS交叉類型&聯(lián)合類型(四)
基礎(chǔ)篇 TS類型斷言(五)
基礎(chǔ)篇 TS類型守衛(wèi)(六)
進(jìn)階篇 TS函數(shù)重載(七)
進(jìn)階篇 TS泛型(八)
進(jìn)階篇 TS裝飾器(九)

類型守衛(wèi)

在前幾篇介紹了斷言,在使用斷言時我們已經(jīng)確定了變量的類型,確定該類型時一定存在(否則則會欺騙編譯,運行時報錯),那么為什么還要類型守衛(wèi)呢?因為類型斷言還是需要借助類型守衛(wèi)的,類型守衛(wèi)主要是用來判斷未知類型是不是所需要的類型
類型守衛(wèi)主要包括四種方式:

  • in
  • typeof
  • instanceof
  • 自定義類型

1、in- 定義屬性場景下內(nèi)容的確認(rèn)

先寫兩個接口Teacher、Student,然后將這兩個接口進(jìn)行聯(lián)合聲明,使用in來判斷屬性是否在傳遞的參數(shù)中,然后分別作輸出。
缺點用 in 關(guān)鍵字縮小數(shù)據(jù)類型必須有一個獨特的屬性作為判別標(biāo)準(zhǔn),否則不能用 in 關(guān)鍵字

interface Teacher{ name:string; courses:string; } interface Student{ name:string; study:string; } type Class = Teacher | Student; function getInfo(val:Class){ //此時val類型縮小為Teacher類型 if('courses' in val){ console.log(val.courses) } //此時val類型縮小為Student類型 if('study' in val){ console.log(val.study) } } getInfo({ name: 'student', study: "Philosophy" }); //打印結(jié)果為Philosophy,因為傳參中含有study屬性,所以走了第二個判斷 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

2、typeof-類型分類場景下的身份確認(rèn)

為什么用typeof做類型守衛(wèi)呢?因為typeof能判斷JS基本數(shù)據(jù)類型。typeof只能識別以下類型:

  • Boolean
  • String
  • Undefined
  • Function
  • Number
  • Bigint
  • Symbol

寫法typeof a,a是變量(基本數(shù)據(jù)類型)

奇怪為什么typeof不能識別null呢?

let a= null typeof a;//object 
  • 1
  • 2

在這里插入圖片描述
null是一個只有一個值的特殊類型,表示一個空對象引用,可以用來清空對象,它是object 類型是歷史遺留下來的問題,曾提議改為null類型,被拒絕了。
typeof 識別其他的類型比如數(shù)組,正則等都是object類型

let a =[1] typeof a;//Object var reg = RegExp("a","i"); typeof reg//reg 
  • 1
  • 2
  • 3
  • 4

typeof 怎么起到守衛(wèi)的作用呢,通過typeof判斷變量類型然后執(zhí)行相應(yīng)的邏輯,具體如下:

function class(name: string, score: string | number) { //識別到sore為number類型 if (typeof score === "number") { return "teacher:" + name + ":" + score; } //識別到sore為string類型 if (typeof score === "string") { return "student:" + name + ":" + score; } } 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

上面案例的傳參都會基本類型,當(dāng)傳一個對象時候,我們也可以用對象中的屬性來進(jìn)行判斷,比如:

interface A{ a:string; } interface B{ a:number; } type Class = A | Bfunction getInfo(val:Class){ //判斷val的屬性a的類型為number類型 if(typeof val.a === "number"){ console.log('B:'+ val.a) } //判斷val的屬性a的類型為string類型 if(typeof val.a === "string"){ console.log('A' + val.a) } } 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

3、instanceof-類型分類場景下的身份確認(rèn)

為什么用instanceof呢?因為typeof有局限性,引用類型比如數(shù)組,正則等無法精確識別是哪一個種型,instanceof能夠識別變量(比如實例對象)是否屬于這個類。instanceof不能檢測原始值類型的值,但是原始值對應(yīng)的對象格式實例則可以檢測。具體instanceof是怎么做類型守衛(wèi)的呢?

  • 寫法a instanceof b,a是參數(shù),b是一般都是接口類型。
interface Teacher{ name:string; courses:string; } interface Student{ name:string; study:string; } type Class = Teacher | Student; function getInfo(val:Class){ //判斷val的類型是否是定義的接口Teacher類型 if(val instanceof Teacher){ console.log('teacher:'+ val.courses) } //判斷val的類型是否是定義的接口Student類型 if(val instanceof Student){ console.log('student' + val.study) } } 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

4、自定義類型

TS中有一個關(guān)鍵字is可以判斷變量是否屬于某種類型。

  • 寫法a is b,意思是a是b類型,a是函數(shù)參數(shù),也可以是this關(guān)鍵字,this關(guān)鍵字一般用在累中判斷,b可以是接口類型,b也可以是numberstring等其他合法的TS類型。這種寫法稱作類型謂詞,使用類型謂詞的函數(shù)稱為類型謂詞函數(shù),該函數(shù)的返回值必須的boolean類型。
  • 使用:先定義一個變量,該變量表示是否是某種類型,比如以下定義了isTeacher,代表了參數(shù)clsTeacher類型,然后用這個變量來判斷。

(1)函數(shù)參數(shù)形式

函數(shù)中的參數(shù)類型為多個類型,通過is關(guān)鍵字自定義類型,將函數(shù)參數(shù)精確到某種類型,然后再執(zhí)行相應(yīng)的邏輯。

interface Teacher{ name:string; courses:string; } interface Student{ name:string; study:string; } const isTeacher = function (cls: Teacher | Student): cls is Teacher { return 'courses' in cls; } const getName = (cls: Teacher | Student) => { if(isTeacher(cls)) { return cls.courses; } } 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

(2)this形式

下面代碼中的 User 是抽象類,不能被實例化,Staff 和 Student 都繼承自 User。實例方法 isStaff 用于將類型收窄為 Staff,實例方法 isStudent 用于將類型收窄為 Student

abstract class User { name: string; constructor(name: string) { this.name = name; } isStudent(): this is Student { return this instanceof Student; } isStaff(): this is Staff { return this instanceof Staff; } } class Student extends User{ study: string; constructor(name: string, study: string) { super(name) this.study = study } } class Staff extends User { workingYears: number; constructor(name: string, workingYears: number) { super(name) this.workingYears = workingYears } } function judgeClassType(obj: User) { if (obj.isStaff()) { // obj的類型被縮小為 Staff } else if (obj.isStudent()){ // obj 的類型被縮小為 Student } }

藍(lán)藍(lán)設(shè)計建立了UI設(shè)計分享群,每天會分享國內(nèi)外的一些優(yōu)秀設(shè)計,如果有興趣的話,可以進(jìn)入一起成長學(xué)習(xí),請加藍(lán)小助,微信號:ben_lanlan,報下信息,藍(lán)小助會請您入群。歡迎您加入噢~~希望得到建議咨詢、商務(wù)合作,也請與我們聯(lián)系01063334945。

分享此文一切功德,皆悉回向給文章原作者及眾讀者. 免責(zé)聲明:藍(lán)藍(lán)設(shè)計尊重原作者,文章的版權(quán)歸原作者。如涉及版權(quán)問題,請及時與我們?nèi)〉寐?lián)系,我們立即更正或刪除。

藍(lán)藍(lán)設(shè)計m.wowo44.com )是一家專注而深入的界面設(shè)計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計、BS界面設(shè)計 、 cs界面設(shè)計 、 ipad界面設(shè)計 、 包裝設(shè)計 、 圖標(biāo)定制 、 用戶體驗 、交互設(shè)計、 網(wǎng)站建設(shè) 平面設(shè)計服務(wù)UI設(shè)計公司、界面設(shè)計公司、UI設(shè)計服務(wù)公司、數(shù)據(jù)可視化設(shè)計公司、UI交互設(shè)計公司、高端網(wǎng)站設(shè)計公司、UI咨詢、用戶體驗公司、軟件界面設(shè)計公司

日歷

鏈接

個人資料

存檔

国产性猛交xx乱_性色国产成人久久久精品_亚洲成年人av_亚洲av片不卡无码久久_日本精品一二三_久久免费精品国产_欧美成人精品一区二区综合免费_无码人妻丰满熟妇区毛片蜜桃精品_四虎永久免费影院_国产一区二区三区四区在线
欧美日韩免费观看一区三区| 欧美精品一区二| 亚洲区小说区图片区qvod| 国产真实精品久久二三区| 男男做爰猛烈叫床爽爽小说 | 国产av一区二区三区传媒| 色综合天天做天天爱| 欧美激情一区二区三区全黄| 国产一区二区导航在线播放| 亚洲色图第四色| 久久久高清一区二区三区| 国产一区在线不卡| 日韩一区二区三区四区视频| 国产亚洲短视频| 国产精品99久久久久久有的能看| 日韩不卡av在线| 欧美—级在线免费片| 国产精品123| 日韩欧美综合视频| 亚洲三级视频在线观看| av一区二区不卡| 欧美亚一区二区| 亚洲高清一区二区三区| 亚洲啪av永久无码精品放毛片| 欧美美女一区二区三区| 日韩国产欧美在线视频| 成人精品999| 国产午夜精品福利| 国产成人av影院| 一本色道a无线码一区v| 亚洲一区在线电影| 五月开心播播网| 久久综合国产精品| 成人一区在线看| 欧美无乱码久久久免费午夜一区 | 亚洲主播在线观看| 99re这里只有| 久久综合久久鬼色| 成人污污视频在线观看| 欧美综合天天夜夜久久| 天天做天天摸天天爽国产一区| 欧美黑人欧美精品刺激| 国产午夜一区二区三区| 欧美四级电影在线观看| 国产欧美日韩另类一区| 视频一区二区中文字幕| 91视视频在线观看入口直接观看www | 国产污在线观看| 在线观看成人免费视频| 美女在线一区二区| 亚洲AV无码久久精品国产一区| 欧美日韩国产成人在线免费| 老司机精品视频在线| 911国产在线| 亚洲一区二区三区三| 在线视频第一页| 亚洲精品成人少妇| 90岁老太婆乱淫| 亚洲欧美偷拍三级| 波多野结衣 在线| 中文字幕一区二区三| 亚州av综合色区无码一区| 国产日韩欧美一区二区三区综合| 91在线精品一区二区三区| 日韩免费看的电影| 成人av网址在线| 日韩三级视频中文字幕| 成人黄色a**站在线观看| 日韩一区二区在线观看视频| 成人手机在线视频| 日韩一区和二区| 成人性生交大片免费看视频在线| 91麻豆精品国产91久久久| 国产 欧美在线| 欧美一二三四区在线| 成人av网站大全| 精品国产乱码久久久久久浪潮 | 综合av第一页| 成人精品999| 亚洲午夜精品网| 免费在线观看黄色小视频| 日韩和欧美一区二区| 色婷婷久久久亚洲一区二区三区| 另类小说综合欧美亚洲| 欧美日韩综合一区| 成人美女在线视频| 久久综合色一综合色88| 95视频在线观看| 1024成人网色www| 日韩女同一区二区三区| 五月综合激情网| 91黄色免费观看| 国产精品一区不卡| 精品久久人人做人人爽| 国产69视频在线观看| 亚洲美女免费在线| 精品无码一区二区三区蜜臀| 久久福利资源站| 日韩一区二区在线观看视频播放| 亚洲精品久久久久久| 综合激情成人伊人| 黑鬼狂亚洲人videos| 国产一区二区三区视频在线播放| 欧美一级理论片| www.四虎精品| 一区二区三区四区蜜桃| 在线免费观看亚洲视频| 国产福利91精品一区二区三区| 精品国产sm最大网站| 给我看免费高清在线观看| 午夜一区二区三区在线观看| 欧美视频一区二区三区在线观看| 波多野结衣精品在线| 国产精品美日韩| 91n在线视频| 国产福利精品导航| 中文字幕av一区二区三区| 9.1片黄在线观看| 韩日av一区二区| 久久免费偷拍视频| 国产精品成人无码免费| 久久99精品久久久| 精品成人一区二区三区四区| 性欧美13一14内谢| 久久电影网电视剧免费观看| 欧美成人性战久久| 欧美日韩高清丝袜| 精品一区二区三区免费视频| 欧美精品一区二区在线观看| 欧洲av一区二区三区| 国精产品一区一区三区mba桃花 | 五月天av网站| av爱爱亚洲一区| 一区二区三区蜜桃| 欧美日韩一区中文字幕| 91九色蝌蚪porny| 秋霞影院一区二区| www一区二区| 91视频最新网址| 不卡一区二区三区四区| 亚洲久本草在线中文字幕| 欧美网站大全在线观看| 免费不卡的av| 蜜桃在线一区二区三区| 久久久美女毛片| 国产第一页浮力| 91丨九色丨蝌蚪富婆spa| 亚洲观看高清完整版在线观看| 欧美一级片在线看| 亚洲综合欧美综合| 大尺度一区二区| 一区二区三区 在线观看视频| 欧美理论片在线| 中文字幕免费高清| 人与嘼交av免费| 精品国产aⅴ一区二区三区东京热| 国产精品久久久久影院亚瑟 | 日本精品在线观看视频| 国产精品一卡二卡| 亚洲乱码国产乱码精品精98午夜| 欧美日韩黄色影视| 日本少妇高潮喷水xxxxxxx| 国产高清久久久| 亚洲一级电影视频| 精品国产乱码久久久久久1区2区| 三上悠亚作品在线观看| 久久久久亚洲av无码网站| 美国毛片一区二区| 国产精品理论在线观看| 欧美日韩久久久久久| 亚洲理论片在线观看| 波多野结衣中文字幕一区| 天天操天天干天天综合网| 久久精子c满五个校花| 色婷婷综合激情| 超碰97在线资源站| 国产不卡在线播放| 亚洲18女电影在线观看| 国产亚洲欧美一区在线观看| 欧洲激情一区二区| 最近中文字幕在线mv视频在线 | 一级黄色片大全| 成人av电影在线观看| 日韩av电影免费观看高清完整版| 久久久久久**毛片大全| 欧美午夜电影网| 一本在线免费视频| 久久久无码人妻精品无码| 国内精品在线播放| 亚洲一区二区三区四区五区黄 | 欧美专区在线观看一区| 亚洲av无码一区二区三区人| 久久久久亚洲av片无码v| 黄色资源网久久资源365| 一片黄亚洲嫩模| 国产亚洲精品超碰| 欧美一级生活片| 91久久精品一区二区二区| 色欲狠狠躁天天躁无码中文字幕| 久久黄色一级视频|