Střídání aktivních stylů v JavaScriptu
V předchozí lekci jsme se naučili aktivovat buňky kliknutím na ně. Nyní udělejme tak, aby se střídaly barvy: nechť první buňka je červená, druhá - zelená, třetí - opět červená a tak dále.
K vyřešení tohoto úkolu již budeme potřebovat dvě CSS třídy:
.color1 {
background: red;
}
.color2 {
background: green;
}
Implementujme popsané střídání:
let tds = document.querySelectorAll('#table td');
let color = 'color1';
for (let td of tds) {
td.addEventListener('click', function() {
if (color == 'color1') {
color = 'color2'
} else {
color = 'color1'
}
this.classList.add(color);
});
}
Prostudujte si můj kód a poté samostatně opakujte řešení této úlohy.
Střídání více barev z pole
Nyní předpokládejme, že chceme střídat ne dvě barvy, ale libovolný počet. Pro tento účel ukládejme pole CSS tříd:
let colors = ['color1', 'color2', 'color3'];
Napišme barvy pro naše třídy:
.color1 {
background: red;
}
.color2 {
background: green;
}
.color3 {
background: yellow;
}
A nyní implementujme střídání:
let tds = document.querySelectorAll('#table td');
let i = 0;
let colors = ['color1', 'color2', 'color3'];
for (let td of tds) {
td.addEventListener('click', function() {
this.classList.add(colors[i]);
i++;
if (i == colors.length) {
i = 0;
}
});
}
Vysvětlete, jak funguje výše uvedený kód.