--- title: Reflect.ownKeys() slug: Web/JavaScript/Reference/Global_Objects/Reflect/ownKeys tags: - ECMAScript 2015 - JavaScript - Method - Reference - Reflect translation_of: Web/JavaScript/Reference/Global_Objects/Reflect/ownKeys --- <div>{{JSRef}}</div> <p>静的な <strong><code>Reflect.ownKeys()</code></strong> メソッドは、 <code>target</code> オブジェクトが持つプロパティキーの配列を返します。</p> <div>{{EmbedInteractiveExample("pages/js/reflect-ownkeys.html")}}</div> <div class="hidden">このデモのソースファイルは GitHub リポジトリに格納されています。デモプロジェクトに協力したい場合は、 <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples</a> をクローンしてプルリクエストを送信してください。</div> <h2 id="Syntax" name="Syntax">構文</h2> <pre class="syntaxbox notranslate">Reflect.ownKeys(<var>target</var>) </pre> <h3 id="Parameters" name="Parameters">引数</h3> <dl> <dt><code><var>target</var></code></dt> <dd>キーを取得する対象のオブジェクト</dd> </dl> <h3 id="Return_value" name="Return_value">返値</h3> <p><code><var>target</var></code> オブジェクトが持つプロパティキーの {{jsxref("Array")}} 。</p> <h3 id="Exceptions" name="Exceptions">例外</h3> <p>{{jsxref("TypeError")}}: <code><var>target</var></code> が {{jsxref("Object")}} ではない場合</p> <h2 id="Description" name="Description">解説</h2> <p><code>Reflect.ownKeys</code> メソッドは、対象のオブジェクトが持つプロパティキーの配列を返します。この返値は、<code>{{jsxref("Object.getOwnPropertyNames", "Object.getOwnPropertyNames(target)", "", 1)}}.concat({{jsxref("Object.getOwnPropertySymbols", "Object.getOwnPropertySymbols(target)", "", 1)}})</code> と同じです。</p> <h2 id="Examples" name="Examples">例</h2> <h3 id="Using_Reflect.ownKeys" name="Using_Reflect.ownKeys">Reflect.ownKeys() の使用</h3> <pre class="brush: js notranslate">Reflect.ownKeys({z: 3, y: 2, x: 1}) // [ "z", "y", "x" ] Reflect.ownKeys([]) // ["length"] let sym = Symbol.for('comet') let sym2 = Symbol.for('meteor') let 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) ] // 数字順のインデックス、 // 挿入順の文字列、 // 挿入順のシンボル </pre> <h2 id="Specifications" name="Specifications">仕様書</h2> <table class="standard-table"> <thead> <tr> <th scope="col">仕様書</th> </tr> </thead> <tbody> <tr> <td>{{SpecName('ESDraft', '#sec-reflect.ownkeys', 'Reflect.ownKeys')}}</td> </tr> </tbody> </table> <h2 id="Browser_compatibility" name="Browser_compatibility">ブラウザーの互換性</h2> <p>{{Compat("javascript.builtins.Reflect.ownKeys")}}</p> <h2 id="See_also" name="See_also">関連情報</h2> <ul> <li>{{jsxref("Reflect")}}</li> <li>{{jsxref("Object.getOwnPropertyNames()")}}</li> </ul>