亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

javascript - typescript關于接口,對象字面量額外屬性檢測問題,為什么使用斷言或者變量時就不會檢測額外屬性?

瀏覽:90日期:2023-04-27 08:52:32

問題描述

interface SquareConfig { color?: string; width?: number;}function createSquare(config: SquareConfig): { color: string; area: number } { // ...}let mySquare = createSquare({ colour: 'red', width: 100 });

ts編譯這段代碼時會拋錯,但是使用如下兩種方式就不會拋錯,這是什么原理?官網的解釋讓我無法理解,只會讓我覺得ts語法好隨便...

let mySquare = createSquare({ width: 100, opacity: 0.5 } as SquareConfig);

或者

let squareOptions = { colour: 'red', width: 100 };let mySquare = createSquare(squareOptions);

這樣都不會報錯,使用斷言的時候(as/<>)是會按照什么規則比照接口嗎?然后將對象字面量復制給變量,我知道這是對象的一個引用指針,但是這樣為什么就不會檢測額外的屬性了呢?官網地址

問題解答

回答1:

第一個例子:as 不是斷言吧 as 是強制轉化 就說明你知道你要做的事情 當然 ts 也就讓你編譯過了第二個例子 好像本來就應該過的吧 color 你又不是一定要; colour 是另外一個屬性了以前不過的原因是 ts 對 對象字面量有獨特的 check 罷了

回答2:

as 是強制類型轉換,強制把一個變量當作另一種類型使用,運行時出問題你自己負責。

使用對象字面量賦值對象的檢測邏輯和使用變量賦值對象的機制不一樣。

interface SquareConfig { color?: string; width?: number;}function test(config: SquareConfig): void {}let a = { colour: 'red', width: 100 };// 不報錯, typeof a 與 SquareConfig 類型兼容let b: SquareConfig = a; // 報錯,聲明 c 是 SquareConfig 類型但是給了不存在的屬性let c: SquareConfig = { colour: 'red', width: 100 }; // 報錯,原因和上面類似test({ colour: 'red', width: 100 })// 不報錯,強制把這個對象字面量當 SquareConfig 類型使用,出問題你自己背鍋let d: SquareConfig = <SquareConfig> { colour: 'red', width: 100 };

標簽: JavaScript
主站蜘蛛池模板: 欧美日韩国产一区二区三区欧 | 一级特级全黄 | 国产专区自拍 | 日韩成人黄色 | 毛片在线视频在线播放 | 全免费午夜一级毛片一级毛 | 真实一级一级一片免费视频 | 国产 日韩 欧美 亚洲 | 激情五月色综合色婷婷 | 午夜影院欧美 | 欧美日韩另类国产 | 国产精品久久久久久久毛片 | 日韩毛片大全免费高清 | 国产精品视频免费 | 日韩精品福利视频一区二区三区 | 理论片亚洲| 午夜国产精品影院在线观看 | 黄色污在线观看 | 色屁屁www影院免费观看入口 | 国产主播福利精品一区二区 | 国产日韩精品欧美一区色 | 国产妇女性爽视频免费 | 色一情一伦一区二区三 | 日韩欧美三区 | 国产亚洲精品一区999 | 久久国产首页 | 六月丁香婷婷色狠狠久久 | 国产成人综合怡春院精品 | 黄片毛片免费看 | 日韩精品中文字幕视频一区 | 黄视频在线播放 | 日韩中文字幕视频在线观看 | 国产亚洲一区二区手机在线观看 | 国产在线观看91精品亚瑟 | 日本护士做xxxxxx视频 | 免费性 | 青草娱乐极品免费视频 | 精品国产欧美另类一区 | 大陆1区二区三区 | 九九热亚洲精品综合视频 | 黑人超大 |