⊗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; } }); }

Обяснете как работи предоставеният от мен код.

Български
AfrikaansAzərbaycanবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Ние използваме бисквитки за работата на сайта, анализ и персонализация. Обработката на данни се извършва в съответствие с Политика за поверителност.
приемам всички настройки отхвърляне