嫩草影院久久99_老司机午夜网站国内精品久久久久久久久_久久夜色精品国产_国产一级做a爰片久久毛片

【TypeScript】TS類型守衛(六)

2023-1-13    前端達人

專欄介紹

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

TS系列 標題
基礎篇 TS入門(一)
基礎篇
TS類型聲明(二)
基礎篇 TS接口類型(三)
基礎篇 TS交叉類型&聯合類型(四)
基礎篇 TS類型斷言(五)
基礎篇 TS類型守衛(六)
進階篇 TS函數重載(七)
進階篇 TS泛型(八)
進階篇 TS裝飾器(九)

類型守衛

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

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

1、in- 定義屬性場景下內容的確認

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

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" }); //打印結果為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-類型分類場景下的身份確認

為什么用typeof做類型守衛呢?因為typeof能判斷JS基本數據類型。typeof只能識別以下類型:

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

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

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

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

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

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

typeof 怎么起到守衛的作用呢,通過typeof判斷變量類型然后執行相應的邏輯,具體如下:

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

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

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-類型分類場景下的身份確認

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

  • 寫法a instanceof b,a是參數,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中有一個關鍵字is可以判斷變量是否屬于某種類型。

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

(1)函數參數形式

函數中的參數類型為多個類型,通過is關鍵字自定義類型,將函數參數精確到某種類型,然后再執行相應的邏輯。

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 } }

藍藍設計建立了UI設計分享群,每天會分享國內外的一些優秀設計,如果有興趣的話,可以進入一起成長學習,請加藍小助,微信號:ben_lanlan,報下信息,藍小助會請您入群。歡迎您加入噢~~希望得到建議咨詢、商務合作,也請與我們聯系01063334945。

分享此文一切功德,皆悉回向給文章原作者及眾讀者. 免責聲明:藍藍設計尊重原作者,文章的版權歸原作者。如涉及版權問題,請及時與我們取得聯系,我們立即更正或刪除。

藍藍設計m.sdgs6788.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務UI設計公司、界面設計公司、UI設計服務公司、數據可視化設計公司、UI交互設計公司、高端網站設計公司、UI咨詢、用戶體驗公司、軟件界面設計公司

日歷

鏈接

個人資料

藍藍設計的小編 http://m.sdgs6788.com

存檔

嫩草影院久久99_老司机午夜网站国内精品久久久久久久久_久久夜色精品国产_国产一级做a爰片久久毛片
<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • 欧美在线资源| 亚洲日本成人在线观看| 性做久久久久久| aa国产精品| 99re成人精品视频| 99pao成人国产永久免费视频| 1024精品一区二区三区| 欧美激情区在线播放| 免费不卡亚洲欧美| 欧美精品在线一区| 国产精品美女久久久久av超清| 欧美日韩一区二区高清| 国产精品久久久91| 国产情侣久久| 亚洲国产国产亚洲一二三| 在线观看一区二区精品视频| 亚洲国产美女精品久久久久∴| 亚洲国产成人午夜在线一区| 亚洲伦伦在线| 亚洲欧美日韩综合aⅴ视频| 国产精品亚洲成人| 激情久久久久久久| 日韩亚洲欧美精品| 午夜视频在线观看一区| 久久亚洲免费| 亚洲精品社区| 久久av一区二区三区漫画| 欧美11—12娇小xxxx| 欧美调教视频| 欧美午夜精品久久久久久浪潮 | 美日韩在线观看| 日韩午夜av在线| 欧美一区二区三区在线播放| 久久影视三级福利片| 欧美视频一区二| 精品成人一区| 亚洲欧美日韩电影| 欧美电影在线播放| 欧美亚洲一区| 国产精品v欧美精品∨日韩| 精品电影在线观看| 小黄鸭视频精品导航| 91久久精品国产91久久| 一区二区三区黄色| 欧美国产日本韩| 精品白丝av| 欧美亚洲在线播放| 1769国产精品| 欧美一区二区三区免费视频| 亚洲日韩视频| 免费成人av在线| 狠狠色狠色综合曰曰| 欧美一区二区三区在线| 艳女tv在线观看国产一区| 欧美1区视频| 亚洲成人在线网站| 欧美中文在线观看| 亚洲综合99| 欧美日韩一区自拍| 一区二区三区av| 久久理论片午夜琪琪电影网| 最新日韩在线| 欧美va亚洲va香蕉在线| 精东粉嫩av免费一区二区三区| 亚洲综合日韩在线| 一本久久综合| 国产精品国产三级国产专播精品人| 亚洲日韩欧美视频| 欧美激情精品久久久久久大尺度| 久久经典综合| 黄色亚洲在线| 免费不卡在线观看| 久久人人97超碰精品888| 又紧又大又爽精品一区二区| 麻豆久久婷婷| 另类激情亚洲| 99精品国产在热久久下载| 亚洲精品久久久久久久久久久久久| 欧美国产三级| 日韩午夜免费视频| 亚洲精选久久| 国产精品试看| 老鸭窝91久久精品色噜噜导演| 久久免费午夜影院| 99精品国产在热久久下载| 亚洲视频日本| 国产亚洲人成网站在线观看| 久久久最新网址| 麻豆成人在线播放| 日韩视频在线播放| 亚洲图片欧美午夜| 国产一区二区三区直播精品电影| 快播亚洲色图| 欧美激情久久久久久| 亚洲一区精彩视频| 久久黄色网页| 一区二区三区四区五区在线| 亚洲伊人一本大道中文字幕| 国内精品伊人久久久久av一坑| 久久久久久亚洲精品中文字幕| 欧美成人国产va精品日本一级| 亚洲午夜电影在线观看| 香蕉视频成人在线观看| 亚洲高清视频的网址| 999亚洲国产精| 伊甸园精品99久久久久久| 蜜臀av性久久久久蜜臀aⅴ四虎 | 亚洲欧洲99久久| 一区在线影院| 夜夜嗨av一区二区三区四季av| 亚洲精品国精品久久99热| 这里只有精品丝袜| 欧美在线免费播放| 亚洲尤物精选| 91久久精品国产91久久性色tv | 欧美高清视频www夜色资源网| 国产精品99久久久久久www| 亚洲欧美国产视频| 亚洲精选在线观看| 久久国产主播精品| 亚洲欧美国产精品专区久久| 久久综合福利| 欧美主播一区二区三区美女 久久精品人 | 在线观看视频一区| 亚洲一区一卡| 亚洲视频你懂的| 欧美在线观看一区二区三区| 亚洲美女av在线播放| 久久精品一区二区三区不卡| 亚洲欧美日韩国产综合| 欧美日韩国产一区二区三区地区| 免费成人av| 国产日韩在线播放| 亚洲欧美日韩一区在线观看| 亚洲视频一区在线观看| 欧美不卡三区| 免费亚洲一区二区| 国精品一区二区三区| 亚洲欧美日韩国产一区二区三区| 亚洲视频高清| 国产精品久久久久久久午夜片| 亚洲国产精品久久久久| 亚洲国产精品va在线看黑人| 欧美在线在线| 久久一区亚洲| 欧美va亚洲va日韩∨a综合色| 欧美一区二区成人| 欧美午夜不卡影院在线观看完整版免费| 欧美国产视频在线观看| 亚洲国产日韩欧美在线动漫| 免费成人性网站| 亚洲国产精品一区二区www| 91久久精品国产91久久性色tv| 可以免费看不卡的av网站| 亚洲电影av| 亚洲精品久久久久久久久久久久| 蜜臀av性久久久久蜜臀aⅴ| 亚洲第一主播视频| 一本色道久久精品| 国产精品伦一区| 欧美一区二区女人| 欧美成人第一页| 在线视频日本亚洲性| 欧美午夜电影在线| 欧美一区二区三区视频免费| 国产精品色婷婷| 免费国产一区二区| 欧美好吊妞视频| 亚洲欧洲精品一区二区三区| 欧美黄网免费在线观看| 日韩亚洲成人av在线| 亚洲自拍16p| 在线免费观看日本一区| 欧美日韩国产首页| 久久国产一二区| 亚洲狼人精品一区二区三区| 欧美中文字幕精品| 亚洲国产精品ⅴa在线观看| 欧美精品免费看| 亚洲午夜电影| 亚洲第一中文字幕| 欧美在线影院| 日韩写真在线| 经典三级久久| 国产精品一区二区三区四区| 久久综合色婷婷| 99国产一区| 久久久欧美精品| 亚洲综合999| 在线免费观看成人网| 国产精品青草综合久久久久99| 久久亚洲国产成人| 亚洲在线视频一区| 亚洲国产精品悠悠久久琪琪| 欧美一区二区三区视频在线| 日韩一级免费| 亚洲黄色在线| 影院欧美亚洲| 国产在线精品一区二区中文 | 亚洲一区二区三区免费在线观看|