このページはコミュニティーの尽力で英語から翻訳されました。MDN Web Docs コミュニティーについてもっと知り、仲間になるにはこちらから。

View in English Always switch to English

Reflect.ownKeys()

Baseline 広く利用可能

この機能は広く実装されており、多くのバージョンの端末やブラウザーで動作します。2016年9月以降、すべてのブラウザーで利用可能です。

Reflect.ownKeys() は静的メソッドで、target オブジェクトが持つプロパティキーの配列を返します。

試してみましょう

const object = {
  property1: 42,
  property2: 13,
};

const array1 = [];

console.log(Reflect.ownKeys(object));
// 予想される結果: Array ["property1", "property2"]

console.log(Reflect.ownKeys(array1));
// 予想される結果: Array ["length"]

構文

js
Reflect.ownKeys(target)

引数

target

キーを取得する対象のオブジェクトです。

返値

Array で、target オブジェクト自身のプロパティキー(文字列とシンボルを含む)が含まれます。ほとんどのオブジェクトでは、配列は次の順序になります。

  1. 非負の整数インデックスを昇順の数値順(ただし文字列として)
  2. その他の文字列キー(プロパティ作成順)
  3. シンボルキー(プロパティ作成順)

例外

TypeError

target がオブジェクトではない場合に発生します。

解説

Reflect.ownKeys() は、オブジェクトのすべてのプロパティキーを取得する反射的意味付けを指定します。これは、追加のフィルタリングロジックなしで、列挙可能・列挙不可、文字列・シンボルを問わず、すべての固有プロパティを一回の呼び出しで取得する唯一の方法です。例えば、Object.getOwnPropertyNames()Reflect.ownKeys() の返値を受け取り、文字列値のみにフィルタリングします。一方、Object.getOwnPropertySymbols() はシンボル値のみにフィルタリングします。通常のオブジェクトは [[OwnPropertyKeys]] を実装してシンボルキーの前にすべての文字列キーを返すため、Reflect.ownKeys(target) は通常 Object.getOwnPropertyNames(target).concat(Object.getOwnPropertySymbols(target)) と同等です。ただし、オブジェクトが独自の [[OwnPropertyKeys]] メソッド(プロキシーオブジェクトの ownKeys ハンドラーなど)を持つ場合、キーの順序が異なる可能性があります。

Reflect.ownKeys() は、target[[OwnPropertyKeys]] オブジェクト内部メソッド を呼び出します。

Reflect.ownKeys() の使用

js
Reflect.ownKeys({ z: 3, y: 2, x: 1 }); // [ "z", "y", "x" ]
Reflect.ownKeys([]); // ["length"]

const sym = Symbol.for("comet");
const sym2 = Symbol.for("meteor");
const 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) ]
// 数字順のインデックス、
// 挿入順の文字列、
// 挿入順のシンボル

仕様書

仕様書
ECMAScript® 2027 Language Specification
# sec-reflect.ownkeys

ブラウザーの互換性

関連情報