JS метод Array.entries()
Опис
Метод entries()
призначено для отримання об'єкта ітератора, що представляє індекси та значення кожного елемента у вашому масиві. Він забезпечує спосіб зручного перегляду та обробки кожного елемента окремо. Він відображає кожен елемент масиву як пару ключ-значення, де ключем є індекс елемента, а значенням - сам елемент. Це надає більш структурний погляд на масив і допомагає зрозуміти його внутрішню будову.
Приклад використання:
const fruits = ["apple", "orange", "banana"];
const iterator = fruits.entries();
for (const [index, value] of iterator) {
console.log(`Index: ${index}, Value: ${value}`);
}
// Виведе:
// Index: 0, Value: apple
// Index: 1, Value: orange
// Index: 2, Value: banana
Зверніть увагу, що при використанні методу на розріджених масивах, порожні слоти обробляються як елементи із значенням undefined
. Ця властивість робить entries()
корисним для ідентифікації порожніх місць у вашому масиві.
Порада: | Використовуючи метод |
Порада: | Використовуючи ES6 деструктуризацію, ви можете легко отримати індекс і значення елемента:
|
Порада: |
|
Нотатка: | Важливо зазначити, що метод |
Нотатка: | Хоча |
Порада: | Пам'ятайте, що метод |
Синтаксис
entries()
Параметри
Return
object
Новий ітератор об'єкта (є перелічуваним).
Переглядачі
Переглядач | |||||
---|---|---|---|---|---|
38 |
28 |
8 |
25 |
12 |
Переглядач | ||||
---|---|---|---|---|
38 |
38 |
28 |
8 |
Переглядач | ||
---|---|---|
0.12.0 |
1.0 |
Приклади
У цьому прикладі ми створюємо масив array1
зі значеннями 'a', 'b' і 'c'. Потім ми створюємо ітератор за допомогою методу entries()
для масиву array1
. За допомогою циклу while
та методу next()
ми ітеруємося по ітератору та виводимо кожне значення та його індекс в HTML-елемент <div>
.
У даному прикладі за допомогою циклу for...of
ми проходимося по масиву a
та виводимо на консоль індекс та відповідний елемент. Результатом є виведення наступних значень: 0 'a', 1 'b', 2 'c'.
const a = ["a", "b", "c"];
for (const [index, element] of a.entries()) {
console.log(index, element);
}
// 0 'a'
// 1 'b'
// 2 'c'
У даному прикладі ми створюємо масив array
з елементами "a", "b" і "c". Потім ми використовуємо метод entries()
для отримання ітератора для масиву array
. За допомогою циклу for...of
ми проходимося по елементах ітератора arrayEntries
та виводимо кожен елемент на консоль.
const array = ["a", "b", "c"];
const arrayEntries = array.entries();
for (const element of arrayEntries) {
console.log(element);
}
// [0, 'a']
// [1, 'b']
// [2, 'c']
У даному прикладі, за допомогою циклу for...of
, ми проходимося по ітератору отриманому викликом методу entries()
на масиві [, "a"]
. Враховуючи те, що масив є розрідженим, метод entries()
відвідує всі позиції, навіть порожні, та виводить на консоль відповідні елементи.
for (const element of [, "a"].entries()) {
console.log(element);
}
// [0, undefined]
// [1, 'a']
У даному прикладі ми маємо об'єкт arrayLike
, який не є масивом, але має властивість length
та набір властивостей з ключами 0, 1, 2 і 3. Метод entries()
викликається на об'єкті arrayLike
, використовуючи Array.prototype.entries.call(arrayLike)
. За допомогою циклу for...of
ми ітеруємося по отриманому ітератору та виводимо кожен елемент на консоль.
const arrayLike = {
length: 3,
0: "a",
1: "b",
2: "c",
3: "d", // ігнорується entries() оскільки length = 3
};
for (const entry of Array.prototype.entries.call(arrayLike)) {
console.log(entry);
}
// [ 0, 'a' ]
// [ 1, 'b' ]
// [ 2, 'c' ]