⊗jsPmPrASA 485 of 505 menu

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.

byitrouzlhy