国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

javascript - typescript關(guān)于接口,對(duì)象字面量額外屬性檢測(cè)問題,為什么使用斷言或者變量時(shí)就不會(huì)檢測(cè)額外屬性?

瀏覽:164日期: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編譯這段代碼時(shí)會(huì)拋錯(cuò),但是使用如下兩種方式就不會(huì)拋錯(cuò),這是什么原理?官網(wǎng)的解釋讓我無(wú)法理解,只會(huì)讓我覺得ts語(yǔ)法好隨便...

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

或者

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

這樣都不會(huì)報(bào)錯(cuò),使用斷言的時(shí)候(as/<>)是會(huì)按照什么規(guī)則比照接口嗎?然后將對(duì)象字面量復(fù)制給變量,我知道這是對(duì)象的一個(gè)引用指針,但是這樣為什么就不會(huì)檢測(cè)額外的屬性了呢?官網(wǎng)地址

問題解答

回答1:

第一個(gè)例子:as 不是斷言吧 as 是強(qiáng)制轉(zhuǎn)化 就說明你知道你要做的事情 當(dāng)然 ts 也就讓你編譯過了第二個(gè)例子 好像本來就應(yīng)該過的吧 color 你又不是一定要; colour 是另外一個(gè)屬性了以前不過的原因是 ts 對(duì) 對(duì)象字面量有獨(dú)特的 check 罷了

回答2:

as 是強(qiáng)制類型轉(zhuǎn)換,強(qiáng)制把一個(gè)變量當(dāng)作另一種類型使用,運(yùn)行時(shí)出問題你自己負(fù)責(zé)。

使用對(duì)象字面量賦值對(duì)象的檢測(cè)邏輯和使用變量賦值對(duì)象的機(jī)制不一樣。

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

標(biāo)簽: JavaScript
主站蜘蛛池模板: 马山县| 齐河县| 平远县| 东阳市| 阳新县| 斗六市| 沛县| 阿城市| 綦江县| 文安县| 宣威市| 金沙县| 射洪县| 克拉玛依市| 宾川县| 南开区| 临猗县| 中超| 张家口市| 临泽县| 穆棱市| 克拉玛依市| 德格县| 蓬安县| 丹巴县| 拜城县| 太和县| 浦江县| 沐川县| 沅陵县| 曲水县| 安达市| 通辽市| 高尔夫| 绥化市| 金昌市| 土默特右旗| 横山县| 浦北县| 尼玛县| 丰台区|