Object

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.

Тип Object представляет один из типов данных JavaScript. Он используется для хранения различных коллекций с ключами и более сложных сущностей. Объекты могут быть созданы с использованием конструктора Object() или синтаксиса инициализатора / литерала объекта.

Описание

Почти все объекты в JavaScript являются экземплярами Object; типичный объект наследует свойства (включая методы) от Object.prototype, хотя эти свойства могут быть затенены (т.е. переопределены). Единственные объекты, которые не наследуют от Object.prototype, - это те, у которых прототип null, или которые происходят от других объектов с прототипом null.

Изменения в объекте Object.prototype видны всем объектам с помощью цепочки прототипов, если свойства и методы, подверженные этим изменениям, не переопределены дальше по цепочке прототипов. Это предоставляет очень мощный, хотя и потенциально опасный механизм для переопределения или расширения поведения объектов. Для обеспечения большей безопасности, Object.prototype - единственный объект в основном языке JavaScript, у которого неизменяемый прототип - прототип Object.prototype всегда null и не может быть изменен.

Синтаксис

js
// Инициализатор объекта или литерал
{ [ nameValuePair1[, nameValuePair2[, ...nameValuePairN] ] ] }

// Вызов в качестве конструктора
new Object([value])

Параметры

nameValuePair1, nameValuePair2, ... nameValuePairN

Пары из имён (строки) и значений (любые значения), где имя отделяется от значения двоеточием.

value

Любое значение.

Свойства конструктора Object

Object.length

Имеет значение 1.

Object.prototype

Позволяет добавлять свойства ко всем объектам типа Object.

Методы конструктора Object

Object.assign()

Создаёт новый объект путём копирования значений всех собственных перечислимых свойств из одного или более исходных объектов в целевой объект.

Object.create()

Создаёт новый объект с указанными объектом прототипа и свойствами.

Object.defineProperty()

Добавляет к объекту именованное свойство, описываемое переданным дескриптором.

Object.defineProperties()

Добавляет к объекту именованные свойства, описываемые переданными дескрипторами.

Object.freeze()

Замораживает объект: другой код не сможет удалить или изменить никакое свойство.

Object.getOwnPropertyDescriptor()

Возвращает дескриптор свойства для именованного свойства объекта.

Object.getOwnPropertyNames()

Возвращает массив, содержащий имена всех переданных объекту собственных перечисляемых и неперечисляемых свойств.

Object.getOwnPropertySymbols()

Возвращает массив всех символьных свойств, найденных непосредственно в переданном объекте.

Object.getPrototypeOf()

Возвращает прототип указанного объекта.

Object.is()

Определяет, являются ли два значения различимыми (то есть, одинаковыми)

Object.isExtensible()

Определяет, разрешено ли расширение объекта.

Object.isFrozen()

Определяет, был ли объект заморожен.

Object.isSealed()

Определяет, является ли объект запечатанным (sealed).

Object.keys()

Возвращает массив, содержащий имена всех собственных перечислимых свойств переданного объекта.

Object.observe()

Асинхронно наблюдает за изменениями в объекте.

Object.preventExtensions()

Предотвращает любое расширение объекта.

Object.seal()

Предотвращает удаление свойств объекта другим кодом.

Object.setPrototypeOf()

Устанавливает прототип (т.е. внутреннее свойство [[Prototype]])

Экземпляры и прототип объекта Object

Все объекты в JavaScript являются потомками Object; все объекты наследуют методы и свойства из прототипа объекта Object.prototype, хотя они и могут быть переопределены. Например, прототипы других конструкторов переопределяют свойство constructor и предоставляют свои собственные методы toString(). Изменения в объекте прототипа Object распространяются на все объекты до тех пор, пока свойства и методы, учитывающие эти изменения, не переопределяются дальше по цепочке прототипов.

Свойства

Object()

Превращает входные данные в объект.

Object.prototype.constructor

Указывает функцию, которая создает прототип объекта.

Object.prototype.__proto__ Устарело

Указывает на объект, который использовался в качестве прототипа при создании экземпляра объекта.

Методы

Object.prototype.__defineGetter__()

Связывает функцию со свойством, которое при обращении к нему выполняет эту функцию и возвращает ее возвращаемое значение.

Object.prototype.__defineSetter__()

Связывает функцию со свойством, которое при установке выполняет ту функцию, которая изменяет свойство.

Object.prototype.__lookupGetter__()

Возвращает функцию, привязанную в качестве средства получения к указанному свойству.

Object.prototype.__lookupSetter__()

Возвращает функцию, привязанную в качестве установщика к указанному свойству.

Object.prototype.hasOwnProperty()

Возвращает логическое значение, указывающее, содержит ли объект указанное свойство как прямое свойство этого объекта, а не унаследованное через цепочку прототипов.

Object.prototype.isPrototypeOf()

Возвращает логическое значение, указывающее, входит ли объект, у которого вызван метод, в цепочку прототипов другого объекта.

Object.prototype.propertyIsEnumerable()

Возвращает логическое значение, указывающее, является ли указанное свойство свойством объекта enumerable own.

Object.prototype.toLocaleString()

Вызывает toString().

Object.prototype.toString()

Возвращает строковое представление объекта.

Object.prototype.valueOf()

Возвращает примитивное значение указанного объекта.

Примеры

Пример: использование Object с типами undefined и null

Следующие примеры сохраняют пустой объект Object в переменную o:

js
const o = new Object();
const o = new Object(undefined);
const o = new Object(null);

Пример: использование Object для создания объектов Boolean

Следующий пример сохраняет объекты Boolean в переменную o:

js
// эквивалентно o = new Boolean(true);
const o = new Object(true);
js
// эквивалентно o = new Boolean(false);
const o = new Object(Boolean());

Спецификации

Specification
ECMAScript Language Specification
# sec-object-objects

Совместимость с браузерами

BCD tables only load in the browser

Смотрите также