Reflect.ownKeys()
Baseline
Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since сентябрь 2016 г..
Статический метод Reflect.ownKeys()
возвращает массив имён, а также Symbols
собственных полей объекта target
.
Интерактивный пример
const object1 = {
property1: 42,
property2: 13,
};
const array1 = [];
console.log(Reflect.ownKeys(object1));
// Expected output: Array ["property1", "property2"]
console.log(Reflect.ownKeys(array1));
// Expected output: Array ["length"]
Синтаксис
Reflect.ownKeys(target)
Параметры
target
-
Объект
target
, из которого получаем собственные ключи.
Возвращаемое значение
Массив Array
собственных полей объекта target
.
Исключения
Выбрасывает исключение TypeError
, если target
не является Object
.
Описание
Метод Reflect.ownKeys
возвращает массив собственных ключей объекта target
. Эквивалентом этого метода является
.Object.getOwnPropertyNames
(target).concat(Object.getOwnPropertySymbols
(target))
Примеры
>Использование Reflect.ownKeys()
js
Reflect.ownKeys({ z: 3, y: 2, x: 1 }); // [ "z", "y", "x" ]
Reflect.ownKeys([]); // ["length"]
var sym = Symbol.for("comet");
var sym2 = Symbol.for("meteor");
var obj = {
[sym]: 0,
str: 0,
773: 0,
0: 0,
[sym2]: 0,
"-1": 0,
8: 0,
"second str": 0,
};
Reflect.ownKeys(obj);
// [ "0", "8", "773", "str", "-1", "second str", Symbol(comet), Symbol(meteor) ]
// Индексы в порядке их перечисления,
// Строки в порядке их ввода,
// Symbols в порядке их ввода
Спецификации
Specification |
---|
ECMAScript® 2026 Language Specification> # sec-reflect.ownkeys> |
Совместимость с браузерами
Loading…