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 September 2016.

El método keys() devuelve un nuevo objeto Array Iterator que contiene las claves para cada indice en el arreglo.

Pruébalo

Sintaxis

js
keys()

Valor de retorno

Un nuevo objeto iterador Array.

Descripción

Cuando es usado en arreglos dispersos, el método keys() itera las ranuras vacias como si tuvieran el valor undefined

El método keys() es generico. Este solo espera el valor de this que tenga un propiedad length y propiedades con claves enteras.

Ejemplos

Usando keys() en arreglos dispersos

A diferencia de Object.keys(), el cual únicamente incluye las claves que realmente existen en el arreglo, el iterador keys() no ignora los huecos que representan las propiedades faltantes.

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]

Llamando keys() en un objeto que no es un arreglo

El método keys() lee la propiedad length de this y luego produce todos los indices entre 0 y length - 1. Realmente no ocurre ningún acceso al índice.

js
const arrayLike = {
  length: 3,
};
for (const entry of Array.prototype.keys.call(arrayLike)) {
  console.log(entry);
}
// 0
// 1
// 2

Especificaciones

Specification
ECMAScript Language Specification
# sec-array.prototype.keys

Compatibilidad con navegadores

BCD tables only load in the browser

Véase también