Lekcje modułu (2/4)
for…of oraz for…in
JavaScript ma dwie „ergonomiczne” pętle, których nie należy mylić:
for…ofiteruje po wartościach kolekcji iterowalnej (tablica, string, Set, Map...).for…initeruje po enumerowalnych kluczach obiektu.
Są blisko spokrewnione i łatwo je pomylić – użycie niewłaściwej to jedna z pierwszych pułapek języka.
for…of dla tablic i stringów
const colori = ['rosso', 'verde', 'blu'];
for (const c of colori) {
console.log(c); // 'rosso', 'verde', 'blu'
}
for (const ch of 'abc') {
console.log(ch); // 'a', 'b', 'c'
}Nie daje Ci indeksu. Jeśli go potrzebujesz, użyj entries():
for (const [i, c] of colori.entries()) {
console.log(i, c); // 0 rosso, 1 verde, 2 blu
}for…in dla obiektów
const utente = { nome: 'Anna', eta: 30, citta: 'Roma' };
for (const chiave in utente) {
console.log(chiave, utente[chiave]); // 'nome' 'Anna', ...
}Kiedy ich NIE mylić
const colori = ['rosso', 'verde', 'blu'];
// SBAGLIATO: stampa gli indici come stringhe!
for (const x in colori) {
console.log(x); // '0', '1', '2'
}
// GIUSTO
for (const x of colori) {
console.log(x); // 'rosso', 'verde', 'blu'
}Spróbuj sam
Zdefiniuj `concat(words)`, które dla podanej listy stringów zwraca jeden połączony string, rozdzielony spacjami. Użyj for…of.
Pokaż wskazówkę
Kumuluj w stringu; dodaj spację tylko wtedy, gdy to nie jest pierwsze słowo.
Rozwiązanie dostępne po 3 próbach
Ćwiczenie powtórzeniowe
Zdefiniuj `positiveValues(obj)`, które zwraca tablicę z wartościami obiektu będącymi liczbami > 0. Użyj for…in. Kolejność musi być zgodna z kolejnością iteracji kluczy.
Pokaż wskazówkę
Przejdź pętlą for...in po kluczach, filtruj za pomocą typeof oraz > 0, a następnie dodaj (push) do wyników.
Rozwiązanie dostępne po 3 próbach