Редуване на стилове на активация в JavaScript
В предишния урок се научихме да активираме клетки при кликване върху тях. Нека сега направим така, че да се редуват цветовете: нека първата клетка се оцвети в червено, втората - в зелено, третата - отново в червено и така нататък.
За решаването на тази задача ще ни трябват вече два CSS класа:
.color1 {
background: red;
}
.color2 {
background: green;
}
Нека реализираме описаното редуване:
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);
});
}
Разгледайте моя код, а след това самостоятелно повторете решението на тази задача.
Редуване на много цветове от масив
Нека сега искаме да редуваме не два цвята, а произволен брой. За целта нека съхраняваме масив от CSS класове:
let colors = ['color1', 'color2', 'color3'];
Нека напишем цветовете на нашите класове:
.color1 {
background: red;
}
.color2 {
background: green;
}
.color3 {
background: yellow;
}
А сега нека реализираме редуването:
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;
}
});
}
Обяснете как работи предоставеният от мен код.