精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

TypeScript中的類型斷言

開發 前端
本文是關于 TypeScript 中的 type assertions 的,它與其他語言中的類型強制轉換有相似之處,并通過 as 運算符執行。

[[413386]]

本文是關于 TypeScript 中的 type assertions 的,它與其他語言中的類型強制轉換有相似之處,并通過 as 運算符執行。

類型斷言

類型斷言使我們可以覆蓋 TypeScript 為存儲位置計算的靜態類型,這對于解決類型系統的限制很有用。

類型斷言與其他語言中的類型強制轉換有相似之處,但是它們不會引發異常,并且在運行時也不做任何事情(它們確實會靜態執行一些少量的檢查)。

  1. const data: object = ['a', 'b', 'c']; // (A) 
  2.  
  3. // @ts-ignore: Property 'length' does not exist on type 'object'. 
  4. data.length; // (B) 
  5.  
  6. assert.equal( 
  7.   (data as Array<string>).length, 3); // (C) 
  • 在 A 行中,我們把 Array 的類型擴展為 object。
  • 在 B 行中,我們看到此類型不允許訪問任何屬性。
  • 在 C 行中,我們用類型斷言(運算符 as)告訴 TypeScript data 是一個Array?,F在就可以訪問屬性 .length 了。

類型斷言是不得已的方法,應盡可能的避免。他們(暫時)刪除了靜態類型系統為我們提供的安全網。

注意,在 A 行中,我們還覆蓋了 TypeScript 的靜態類型,不過是通過類型注釋完成的。這種覆蓋方式比類型聲明要安全得多,因為你可以做的事情少得多。TypeScript 的類型必須能夠分配給注釋的類型。

(1) 類型斷言的替代語法

TypeScript 對于類型斷言有另一種“尖括號”語法:

  1. <Array<string>>data 

該語法已經過時,并且與 React JSX 代碼(在 .tsx 文件中)不兼容。

(2) 示例:聲明一個接口

為了訪問任意對象 obj 的屬性 .name,我們暫時將 obj 的靜態類型更改為 Named(A行和B行)。

  1. interface Named { 
  2.   name: string; 
  3. function getName(obj: object): string { 
  4.   if (typeof (obj as Named).name === 'string') { // (A) 
  5.     return (obj as Named).name; // (B) 
  6.   } 
  7.   return '(Unnamed)'; 

(3) 示例:聲明索引簽名

在以下代碼中,我們在行 A 用了類型斷言 as Dict ,以便可以訪問其推斷類型為 object 的值的屬性。也就是說,用靜態類型 Dict 覆蓋了推斷的靜態類型 object。

  1. type Dict = {[k:string]: any}; 
  2.  
  3. function getPropertyValue(dict: unknown, key: string): any { 
  4.   if (typeof dict === 'object' && dict !== null && key in dict) { 
  5.     // %inferred-type: object 
  6.     dict; 
  7.  
  8.     // @ ts-ignore:元素隱式具有“any”類型,因為 
  9.     // 類型'string'的表達式不能用于索引類型'{}'。 
  10.     // 在類型“ {}”上沒有找到參數類型為'string'的索引簽名。 
  11.     dict[key]; 
  12.      
  13.     return (dict as Dict)[key]; // (A) 
  14.   } else { 
  15.     throw new Error(); 
  16.   } 

與類型斷言相關的構造

(1) 非空斷言運算符(后綴 !)

如果值的類型是包含 undefined 或 null 類型的聯合,則 non-nullish聲明運算符(或 non-null 聲明運算符)將從聯合中刪除這些類型。我們告訴 TypeScript:“這個值不能是 undefined 或 null。”因此,我們可以執行這兩個值的類型所阻止的操作,例如:

  1. const theName = 'Jane' as (null | string); 
  2.  
  3. // @ts-ignore: Object is possibly 'null'. 
  4. theName.length; 
  5.  
  6. assert.equal( 
  7.   theName!.length, 4); // OK 

(2) 示例 – Maps: .has() 之后的 .get()

使用 Map 方法 .has() 之后,我們知道 Map 具有給定的鍵。遺憾的是,.get() 的結果不能反映這一點,這就是為什么我們必須使用 nullish 斷言運算符的原因:

  1. function getLength(strMap: Map<string, string>, key: string): number { 
  2.   if (strMap.has(key)) { 
  3.     // We are sure x is not undefined: 
  4.     const value = strMap.get(key)!; // (A) 
  5.     return value.length; 
  6.   } 
  7.   return -1; 

由于 strMap 的值永遠不會是 undefined,因此我們可以通過檢查 .get() 的結果是否為 undefined 來檢測丟失的 Map 條目(A 行):

  1. function getLength(strMap: Map<string, string>, key: string): number { 
  2.   // %inferred-type: string | undefined 
  3.   const value = strMap.get(key); 
  4.   if (value === undefined) { // (A) 
  5.     return -1; 
  6.   } 
  7.  
  8.   // %inferred-type: string 
  9.   value; 
  10.  
  11.   return value.length; 

(3) 定值斷言

如果打開 strict 屬性初始化,有時需要告訴 TypeScript 我們確實初始化某些屬性——即使它認為我們不需要這樣做。

這是一個例子,盡管 TypeScript 不應這樣做,但它仍會報錯:

  1. class Point1 { 
  2.   // @ts-ignore: Property 'x' has no initializer and is not definitely 
  3.   // assigned in the constructor. 
  4.   x: number; 
  5.  
  6.   // @ts-ignore: Property 'y' has no initializer and is not definitely 
  7.   // assigned in the constructor. 
  8.   y: number; 
  9.  
  10.   constructor() { 
  11.     this.initProperties(); 
  12.   } 
  13.   initProperties() { 
  14.     this.x = 0
  15.     this.y = 0
  16.   } 

如果我們在 A 行和 B 行中使用“定值分配斷言”(感嘆號),則錯誤會消失:

  1. class Point2 { 
  2.   x!: number; // (A) 
  3.   y!: number; // (B) 
  4.   constructor() { 
  5.     this.initProperties(); 
  6.   } 
  7.   initProperties() { 
  8.     this.x = 0
  9.     this.y = 0
  10.   } 

 

責任編輯:趙寧寧 來源: 前端先鋒
相關推薦

2025-08-20 00:03:00

TypeScriptAssertion函數

2023-10-29 16:18:26

Go接口

2022-04-11 08:42:09

TypeScript子類型定義

2024-05-11 10:19:31

TypeScript類型接口

2022-08-08 09:00:42

TypeScript映射類型

2015-07-08 16:00:32

Foundation

2022-04-10 19:26:07

TypeScript類型語法

2020-12-18 11:35:22

TypeScript語言Java

2022-02-25 09:06:02

TypeScripnever工具

2023-07-16 23:43:05

Go語言模式

2021-08-18 07:56:05

Typescript類型本質

2024-08-12 08:50:17

2025-09-01 07:22:10

inferTypeScripfetch

2022-09-20 14:43:55

TypeScript類型體操

2025-01-20 00:13:19

TypeScript操作符數據類型

2021-06-09 07:55:19

Typescript類型檢查

2024-03-20 00:04:46

TypeScriptas const類型斷言

2022-05-04 09:02:41

TypeScript類型工具

2022-08-10 09:03:35

TypeScript前端

2020-09-15 08:35:57

TypeScript JavaScript類型
點贊
收藏

51CTO技術棧公眾號

国产精品久久久久一区二区国产 | 欧美丝袜激情| 欧美日韩亚洲综合一区 | 亚洲美女毛片| 国产亚洲精品一区二区| 手机看片国产精品| 亚洲天堂免费电影| 亚洲欧美在线观看| 久久精品国产精品青草色艺| 亚洲自拍偷拍另类| aa级大片欧美三级| 久久人人爽人人爽爽久久| 亚洲精品在线视频免费观看| www.26天天久久天堂| 亚洲国产一区二区三区| 亚洲 国产 欧美一区| 亚洲乱码国产乱码精品精软件| 老鸭窝毛片一区二区三区| 欧美精品在线免费播放| 国产成人免费观看网站| 卡通动漫国产精品| 欧美妇女性影城| 日韩av资源在线| 日本乱理伦在线| 欧美国产乱子伦| 九九九九久久久久| 国内精品久久久久久久久久久 | 天堂在线中文字幕| 国产乱子伦视频一区二区三区| 国产xxx69麻豆国语对白| 国产一级av毛片| 亚洲区综合中文字幕日日| 亚洲无限av看| 久久久久亚洲av无码专区桃色| 中文人妻熟女乱又乱精品| 亚洲视频福利| 久久成人这里只有精品| 阿v天堂2014| 69堂免费精品视频在线播放| 亚洲男人的天堂网| 先锋影音亚洲资源| 午夜影院在线视频| 成人毛片老司机大片| 91免费欧美精品| 91麻豆视频在线观看| 蜜臀久久久久久久| 国产精品老牛影院在线观看| 欧美brazzers| 视频一区国产视频| 日本精品久久中文字幕佐佐木| 黄色小视频在线免费看| 欧美午夜一区| 欧美成人午夜免费视在线看片| 国精品人伦一区二区三区蜜桃| 全球成人免费直播| 在线观看亚洲视频| 一级黄色片网址| 第九色区aⅴ天堂久久香| 亚洲人午夜精品免费| 中日韩精品一区二区三区| 亚洲三级性片| 亚洲天堂av女优| 男人的天堂av网| 久久亚洲专区| 久久高清视频免费| 国产小视频在线观看免费| 欧美午夜在线| 2018日韩中文字幕| 欧美精品韩国精品| 视频在线在亚洲| 国产美女搞久久| 97免费观看视频| 国产成人在线看| 久久综合九色99| 国产一级免费在线观看| 国产精品丝袜在线| 老汉色影院首页| 黄页网站大全在线免费观看| 五月天一区二区| av观看免费在线| 日本在线一区二区| 日韩精品一区二区三区蜜臀| 国产肉体xxxx裸体784大胆| 加勒比久久综合| 久久视频这里只有精品| 日本一级黄色录像| 美女精品一区二区| 97在线中文字幕| 三级理论午夜在线观看| 中文无字幕一区二区三区| 久久观看最新视频| 涩涩视频网站在线观看| 欧美日韩视频在线观看一区二区三区| 国内精品国产三级国产aⅴ久| youjizz欧美| 亚洲新中文字幕| 免费在线观看av网址| 国产精品外国| 91手机视频在线观看| 午夜性色福利影院| 亚洲欧美视频一区| 中文字幕乱码人妻综合二区三区 | 国产伦精品一区二区三毛| 男女污污视频在线观看| 亚洲欧美日韩系列| 各处沟厕大尺度偷拍女厕嘘嘘| 日韩第二十一页| 亚洲精品福利在线观看| 精品无码久久久久成人漫画| 免费中文字幕日韩欧美| 亚洲精品免费在线视频| 久蕉在线视频| 亚洲国产精品自拍| 色一情一区二区| 欧美黑人巨大videos精品| 久久精品99国产精品酒店日本| 欧美a∨亚洲欧美亚洲| 国产一区二区三区免费| 午夜精品一区二区在线观看的| 2020国产在线| 欧美日本一区二区在线观看| 丝袜美腿中文字幕| 在线播放一区| 1区1区3区4区产品乱码芒果精品| 国产大学生校花援交在线播放 | 日韩三级毛片| 日韩一区二区三区观看| 粉嫩av懂色av蜜臀av分享| 91精品综合| 国产美女精品视频免费观看| 日夜干在线视频| 亚洲第一成年网| 日本wwww色| 91精品99| 91在线国产电影| 黄色片免费在线观看| 欧美性猛交xxxx乱大交退制版| 午夜理伦三级做爰电影| a91a精品视频在线观看| 狠狠色伊人亚洲综合网站色| jizzjizz中国精品麻豆| 精品剧情在线观看| 国产一级av毛片| 丁香网亚洲国际| 日本免费a视频| 91综合久久爱com| 欧美激情视频一区二区三区不卡| 国产精品怡红院| 亚洲男人电影天堂| 中文字幕人妻无码系列第三区| 亚洲第一偷拍| 成人黄动漫网站免费| 四虎av在线| 亚洲第一免费网站| www.av麻豆| 久久久久久久久97黄色工厂| 欧美成人免费在线观看视频| 日韩av中文字幕一区| 2023亚洲男人天堂| 男女污污视频在线观看| 欧美在线影院一区二区| 人人艹在线视频| 蜜桃91丨九色丨蝌蚪91桃色| 91免费网站视频| 成人在线视频国产| 欧美黑人一级爽快片淫片高清| 可以免费观看的毛片| 午夜精品影院在线观看| 亚洲第一页av| 蜜臀精品久久久久久蜜臀| 在线免费观看一区二区三区| 视频精品一区二区三区| 91精品国产91久久久| 美女做暖暖视频免费在线观看全部网址91| 日韩欧美国产一区二区| 四虎地址8848| 懂色av中文一区二区三区| 男人日女人下面视频| 欧美日韩伦理| 97在线资源站| 伊人久久高清| 美日韩精品免费视频| 午夜国产在线视频| 欧美性色综合网| 欧美精品99久久久| 99re热这里只有精品免费视频| 亚洲天堂av线| 亚洲在线久久| 美乳视频一区二区| 未满十八勿进黄网站一区不卡| 欧美精品福利视频| 成人免费在线电影| 欧美精品一区二区三区蜜臀| av首页在线观看| 一区二区三区不卡视频| 国精产品一区二区三区| 国产精品1024久久| 成人免费毛片播放| 午夜性色一区二区三区免费视频| 另类小说综合网| 国产一区二区三区国产精品| 日本精品久久电影| 性xxxfreexxxx性欧美| 国产亚洲一级高清| 人妻少妇精品无码专区| 欧美日韩国产成人在线91 | 日本高清不卡视频| 黄色一级视频免费观看| 国产精品色婷婷久久58| 亚洲中文字幕无码一区| 激情国产一区二区| 国产日韩成人内射视频| 亚洲精品偷拍| www.-级毛片线天内射视视| 国产精品欧美在线观看| 国精产品99永久一区一区| **精品中文字幕一区二区三区| 日本一本a高清免费不卡| 日本大片在线播放| 久久久久www| 337p日本欧洲亚洲大胆鲁鲁| 精品视频久久久久久| 丰满人妻一区二区三区免费| 欧美一区二区私人影院日本| 伊人网视频在线| 色一情一乱一乱一91av| 你懂的国产视频| 亚洲国产欧美日韩另类综合| 精品国产欧美日韩不卡在线观看| 国产精品婷婷午夜在线观看| av网在线播放| 国产视频不卡一区| 成人免费网站黄| 91蜜桃在线观看| 亚洲av成人片无码| 国产.欧美.日韩| 久久久久无码国产精品一区李宗瑞| 婷婷激情综合| 亚洲日本无吗高清不卡| av中字幕久久| 视频一区视频二区视频三区高| 日韩伦理一区二区三区| 精品午夜一区二区| 久久久伦理片| 国产一区二区在线网站 | 国产真实乱偷精品视频免| 五月婷婷丁香色| 久久精品噜噜噜成人av农村| 中文字幕亚洲乱码| 另类小说视频一区二区| 手机av在线网| 国产高清精品在线| 亚洲熟女一区二区三区| 成人免费高清视频| 日韩精品人妻中文字幕有码| 成人动漫在线一区| 亚洲av无码一区东京热久久| av激情综合网| 日本高清www| 欧美国产精品劲爆| 久久久久99精品成人| 国产精品久99| 精品97人妻无码中文永久在线| 亚洲成av人片一区二区| 国产一级18片视频| 在线视频一区二区免费| 97视频免费在线| 日韩精品一区二区三区蜜臀| 亚洲 欧美 激情 小说 另类| 国产一区二区三区视频| 精品国产丝袜高跟鞋| 欧美激情综合色| 成人直播视频| 91亚洲精品一区| 哺乳一区二区三区中文视频| 欧美高清视频一区二区三区在线观看| 国产a久久精品一区二区三区 | 亚洲免费影院| av亚洲天堂网| 99视频超级精品| 精品手机在线视频| 亚洲综合一区二区| 中文字幕第四页| 91精品国产色综合久久不卡蜜臀| 人妻偷人精品一区二区三区| 在线播放精品一区二区三区 | 天堂av网在线| 日韩亚洲在线观看| 美女搞黄视频在线观看| 国产免费一区视频观看免费 | 亚洲欧美精品一区二区| 日韩在线观看www| 91精品91久久久久久| 亚洲欧洲一二区| 精品国产_亚洲人成在线| 日韩精品2区| 精品久久一二三| 精品一区二区免费| 国产三级国产精品| 亚洲欧洲av一区二区三区久久| 久久草视频在线| 欧美一区三区二区| 欧美男男同志| 欧美精品成人在线| 韩国精品视频在线观看| 久久久com| 欧美区国产区| 亚洲欧洲日本精品| 久久毛片高清国产| 国产午夜福利精品| 日韩一区二区三区av| 91啦中文在线| 欧洲亚洲免费在线| 国产成人一二| 日韩精品福利片午夜免费观看| 人人狠狠综合久久亚洲| 性欧美丰满熟妇xxxx性久久久| 亚洲免费观看高清完整版在线 | 中文字幕精品www乱入免费视频| caoporn-草棚在线视频最| 91欧美精品成人综合在线观看| 国产欧美日韩免费观看| 欧美性大战久久久久xxx| 高清成人免费视频| 男女做暖暖视频| 欧美精品乱人伦久久久久久| 在线免费av电影| 国产精品国产三级国产专播精品人 | 偷拍女澡堂一区二区三区| 一区二区日韩av| 国产成人精品av在线观| 久久精品欧美视频| 国产福利亚洲| 香蕉久久夜色| 极品销魂美女一区二区三区| 国产视频不卡在线| 欧美色国产精品| 91亚洲精选| 国产日韩欧美日韩| 国产精品99在线观看| 日韩av在线中文| 亚洲天堂2014| 国产精品无码免费播放| 久久午夜a级毛片| av日韩久久| 4444在线观看| 国产99久久久久久免费看农村| 久久久久久久福利| 日韩美女视频在线| 色噜噜狠狠狠综合欧洲色8| **亚洲第一综合导航网站| 欧美另类视频| 懂色av粉嫩av蜜乳av| 欧美日韩一区二区在线| 国产免费a∨片在线观看不卡| 国产精品久久激情| 国产精品99一区二区三| 一起草最新网址| 亚洲一卡二卡三卡四卡无卡久久| 日韩性xxxx| 日本精品一区二区三区在线| 精品久久一区| 一起操在线视频| 亚洲一区影音先锋| 外国精品视频在线观看| 欧美在线观看视频| 精品国产乱码久久久久久1区2匹| 久久久久国产一区| 亚洲欧美色图小说| 色一情一乱一乱一区91av| 亚洲情综合五月天| 韩日精品一区| 亚洲免费视频播放| 99在线精品视频| 黄色av网站免费| 久久人人爽人人爽人人片亚洲| 荡女精品导航| 婷婷六月天在线| 亚洲综合激情另类小说区| 加勒比一区二区三区在线| 91精品久久久久久久久久入口| 亚洲视频高清| 成人激情五月天| 亚洲变态欧美另类捆绑| 日本欧美不卡| 国产精品无码电影在线观看| 久久美女艺术照精彩视频福利播放| 一级片免费观看视频| 97精品视频在线观看| 久久美女视频| 欧美肉大捧一进一出免费视频| 欧美三区在线观看| 国产黄色大片在线观看| 无遮挡亚洲一区| hitomi一区二区三区精品| 中文字幕欧美在线观看| 亚洲97在线观看| 91精品婷婷色在线观看| 少妇真人直播免费视频| 欧美成人精精品一区二区频|