除了普通的物件屬性賦值和遍歷之外,我們還可以使用 JavaScript 物件執行許多其他操作。在本文中,我們將了解如何使用它們,包括存取內部屬性、操作屬性描述符和繼承唯讀屬性。
1. 存取內部屬性
JavaScript 物件無法以常規方式存取的內部屬性。內部屬性名稱由雙方括號[[]]包圍,在建立物件時可用。
內部屬性不能動態地加入到現有物件。
內部屬性可以在某些內建 JavaScript 物件中使用,它們儲存ECMAScript規範指定的內部狀態。
有兩種內部屬性,一種操作物件的方法,另一種是儲存資料的方法。例如:
[[Prototype]] — 物件的原型,可以為null或物件
[[Extensible]] — 表示是否允許在物件中動態新增新的屬性
[[PrivateFieldValues]] — 用於管理私有類別欄位
let foo = { a: 1}
let foo = { a: 1}Object.defineProperty(foo, 'b', { value: 2, writable: true, enumerable: true, configurable: true,});
我們也可以使用defineProperty來變更現有屬性的描述符。例如:
let foo = { a: 1}Object.defineProperty(foo, 'a', { value: 2, writable: false, enumerable: true, configurable: true,});
foo.a = 2;
我們也可以使用defineProperty將屬性轉換為getter,如下所示:
'use strict'let foo = { a: 1}Object.defineProperty(foo, 'b', { get() { return 1; } })
foo.b = 2;
const proto = Object.defineProperties({}, { a: { value: 1, writable: false }})const foo = Object.create(proto)
foo.a = 2;
總結
我們可以用 JavaScript 物件做很多我們可能不知道的事情。
首先,某些 JavaScript 物件(例如內建瀏覽器物件)具有內部屬性,這些屬性由雙方括號包圍,它們具有內部狀態,物件建立無法動態新增。 JavaScript物件屬性還具有屬性描述符,該屬性描述符使我們可以控制其值以及可以設定它們的值,還是可以更改其屬性描述符等。 我們可以使用defineProperty來變更屬性的屬性描述符,它也用於新增屬性及其屬性描述符。最後,繼承的唯讀屬性保持只讀狀態,這是有道理的,因為它是從父原型物件繼承而來的。
推薦教學: 《javascript教學》
以上是JavaScript 物件可以做到的幾件事的詳細內容。更多資訊請關注PHP中文網其他相關文章!