⊗jsPmPrASA 485 of 505 menu

Przełączanie stylów aktywacji w JavaScript

W poprzedniej lekcji nauczyliśmy się aktywować komórki poprzez kliknięcie na nich. Zróbmy teraz tak, aby występowało naprzemienne zmienianie kolorów: niech pierwsza komórka będzie kolorowana na czerwono, druga - na zielono, trzecia - znowu na czerwono i tak dalej.

Do rozwiązania tego zadania będziemy potrzebować już dwie klasy CSS:

.color1 { background: red; } .color2 { background: green; }

Zaimplementujmy opisane naprzemienne zmienianie:

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

Przeanalizuj mój kod, a następnie samodzielnie powtórz rozwiązanie tego zadania.

Naprzemienne zmienianie wielu kolorów z tablicy

Załóżmy teraz, że chcemy zmieniać naprzemiennie nie dwa kolory, ale dowolną ich liczbę. W tym celu będziemy przechowywać tablicę klas CSS:

let colors = ['color1', 'color2', 'color3'];

Zapiszmy kolory naszych klas:

.color1 { background: red; } .color2 { background: green; } .color3 { background: yellow; }

A teraz zaimplementujmy naprzemienne zmienianie:

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

Opowiedz, jak działa przedstawiony przeze mnie kod.

Polski
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Wykorzystujemy pliki cookie do działania strony, analizy i personalizacji. Przetwarzanie danych odbywa się zgodnie z Polityką prywatności.
zaakceptuj wszystkie dostosuj odrzuć