⊗jsPmPrASA 485 of 505 menu

Alternance de styles d'activation en JavaScript

Dans la leçon précédente, nous avons appris à activer les cellules en cliquant dessus. Maintenant, faisons en sorte qu'il y ait une alternance de couleurs : que la première cellule soit colorée en rouge, la seconde - en vert, la troisième - à nouveau en rouge, et ainsi de suite.

Pour résoudre cette tâche, nous aurons besoin de deux classes CSS :

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

Implémentons l'alternance décrite :

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

Analysez mon code, puis reproduisez indépendamment la solution de cette tâche.

Alternance de plusieurs couleurs à partir d'un tableau

Supposons maintenant que nous souhaitions alterner non pas deux couleurs, mais un nombre arbitraire. Pour cela, stockons un tableau de classes CSS :

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

Définissons les couleurs de nos classes :

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

Et maintenant, implémentons l'alternance :

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

Expliquez comment fonctionne le code que j'ai présenté.

Français
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Nous utilisons des cookies pour le fonctionnement du site, l'analyse et la personnalisation. Le traitement des données est effectué conformément à la Politique de confidentialité.
accepter tout personnaliser refuser