⊗jsPmPrASA 485 of 505 menu

Чаргаванне стыляў актывацыі на 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; } }); }

Раскажыце, як працуе прыведзены мною код.

esbnhumstr