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

Мен келтирган код қандай ишлашини тушантиринг.

debnuzckkru