Przełączanie stylów aktywacji w JavaScript
W poprzedniej lekcji nauczyliśmy się aktywować komórki poprzez kliknięcie na nich. Zróbmy teraz tak, aby występowało naprzemienne zmienianie kolorów: niech pierwsza komórka będzie kolorowana na czerwono, druga - na zielono, trzecia - znowu na czerwono i tak dalej.
Do rozwiązania tego zadania będziemy potrzebować już dwie klasy CSS:
.color1 {
background: red;
}
.color2 {
background: green;
}
Zaimplementujmy opisane naprzemienne zmienianie:
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);
});
}
Przeanalizuj mój kod, a następnie samodzielnie powtórz rozwiązanie tego zadania.
Naprzemienne zmienianie wielu kolorów z tablicy
Załóżmy teraz, że chcemy zmieniać naprzemiennie nie dwa kolory, ale dowolną ich liczbę. W tym celu będziemy przechowywać tablicę klas CSS:
let colors = ['color1', 'color2', 'color3'];
Zapiszmy kolory naszych klas:
.color1 {
background: red;
}
.color2 {
background: green;
}
.color3 {
background: yellow;
}
A teraz zaimplementujmy naprzemienne zmienianie:
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;
}
});
}
Opowiedz, jak działa przedstawiony przeze mnie kod.