首頁 > web前端 > js教程 > 主體

TypeScript 中 &#Object&#、&#{}&# 與 &#object&# 的差異

王林
發布: 2024-07-24 15:52:30
原創
998 人瀏覽過

在 TypeScript 中,當我們想要定義一個物件類型時,有「Object」、「{}」、「object」等幾個簡潔的選項。他們之間有什麼區別?

對象(大寫)

Object(大寫)描述所有 JavaScipt 物件共有的屬性。它在 TypeScript 庫附帶的lib.es5.d.ts檔案中定義。

The Differences Between

如你所見,它包含了一些常見的屬性,如 toString()、valueOf() 等。

因為它只強調 JavaScript 物件共有的那些屬性。因此,您可以為其指派可裝箱對象,例如字串、布林值、數字、bigint、符號,但反之則不然。

The Differences Between

{}

{} 描述了一個沒有自己的成員的對象,這意味著如果您嘗試存取其屬性成員,TypeScript 會報錯:

The Differences Between

從上面的程式碼範例中,我們可以看到 {} 和 Object(大寫)具有相同的功能。也就是說,它只能存取那些通用的屬性(即使JavaScript程式碼邏輯是正確的),所有可裝箱物件都可以指派給它等等

這是因為 {} 類型可以透過原型鏈存取那些公共屬性,而且它也沒有自己的屬性。因此它的行為與 Object(大寫)類型相同。但它們代表不同的概念。

對象(小寫)

object(小寫)表示任何非原始類型,其程式碼表示如下:

雷雷

這意味著所有非原始類型都不能分配給它,反之亦然。

The Differences Between

點心:記錄

在許多常用函式庫的原始碼中,我們可能會看到Record來表示非原始型別。它與object(小寫)效果相同,但更語義化。


如果您覺得我的內容有幫助,請考慮訂閱。我每週日都會發送 _ 每週時事通訊 _ ,其中包含最新的網頁開發更新。感謝您的支持!

以上是TypeScript 中 &#Object&#、&#{}&# 與 &#object&# 的差異的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:dev.to
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!