⊗jsPmPrASA 485 of 505 menu

Aktivointityylien vuorottaminen JavaScriptillä

Edellisessä oppitunnissa opimme aktivoimaan soluja klikkaamalla niitä. Tehdään nyt niin, että värit vuorottelevat: anna ensimmäisen solun värjätä punaiseksi, toisen vihreäksi, kolmannen taas punaiseksi ja niin edelleen.

Tämän ongelman ratkaisemiseksi tarvitsemme jo kaksi CSS-luokkaa:

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

Toteutetaan kuvattu vuorottelu:

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

Analysoi koodini ja toista sitten itsenäisesti tämän tehtävän ratkaisu.

Useiden värien vuorottelu taulukosta

Oletetaan nyt, että haluamme vuorotella ei kahta väriä, vaan mielivaltaisen määrän. Tallennetaan tätä varten CSS-luokkien taulukko:

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

Kirjoitetaan luokkiemme värit:

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

Ja nyt toteutetaan vuorottelu:

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

Kerro, kuinka esittämäni koodi toimii.

Suomi
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Käytämme evästeitä verkkosivuston toiminnalle, analytiikalle ja personoinnille. Tietojen käsittely tapahtuu Tietosuojakäytännön mukaisesti.
hyväksy kaikki mukauta hylkää