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.
El método keys()
devuelve un nuevo objeto Array Iterator que contiene las claves para cada indice en el arreglo.
Pruébalo
Sintaxis
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.
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.
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