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é.