Array.prototype.keys()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since May 2018.
試してみましょう
構文
js
keys()
引数
なし。
返値
新しい反復可能なイテレーターオブジェクトです。
解説
例
疎配列に対する keys() の呼び出し
配列に実際に存在するキーだけを処理する Object.keys()
とは異なり、 keys()
イテレーターは見つからないプロパティを表す穴を無視しません。
js
const arr = ["a", , "c"];
const sparseKeys = Object.keys(arr);
const denseKeys = [...arr.keys()];
console.log(sparseKeys); // ['0', '2']
console.log(denseKeys); // [0, 1, 2]
配列以外のオブジェクトに対する keys() の呼び出し
keys()
メソッドは this
の length
プロパティを読み込み、 0 から length - 1
までのすべての整数インデックスを返します。実際にはインデックスアクセスは行われません。
js
const arrayLike = {
length: 3,
};
for (const entry of Array.prototype.keys.call(arrayLike)) {
console.log(entry);
}
// 0
// 1
// 2
仕様書
Specification |
---|
ECMAScript Language Specification # sec-array.prototype.keys |
ブラウザーの互換性
BCD tables only load in the browser