Чаргаванне стыляў актывацыі на 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;
}
});
}
Раскажыце, як працуе прыведзены мною код.