Discussion autour des boucles
Amélioration du code
La structuration de valeurs dans un tableau, nécessite une boucle pour réaliser un parcours des valeurs.Exemple :
Affichons simplement les éléments d'un tableau :- let array = [1, 2, 3];
- for (let i = 0; i < array.length; i++) {
- let current = array[i];
- console.log(current); // affichage
- }
Imaginons l'affichage des valeurs comme une action.
ou
- for (let i = 0; i < array.length; i++) {
- let current = array[i];
- actionAffichage(current); // affichage
- }
Affichage des positifs
Pour afficher les valeurs positives, il est facile de créer une condition ; la fonction précédente devient.- for (let i = 0; i < array.length; i++) {
- let current = array[i];
- if (current>0) actionAffichage(current);
- }
ou
- for (let i = 0; i < array.length; i++) {
- let current = array[i];
- actionAffichagePositif(current);
- }
Affichage des Négatifs
Pour afficher les valeurs négatives, il est facile de créer une condition ; la fonction précédente devient.- for (let i = 0; i < array.length; i++) {
- let current = array[i];
- actionAffichageNégatif(current);
- }
Bilans
Pour chaque type d'affichage, il est nécessaire de redéfinir la boucle.
Améliorations
Nous allons encapsuler le code de la boucle dans une fonction forEach. 👿
Il nous reste à réfléchir sur le passage des actions (positif, négatif ...)
comme paramètres.
Ainsi, "afficher quelque chose" peut être vu comme une fonction.
Les fonctions étant des variables et comme les variables peuvent être passées en paramètres, on peut passer "afficher quelque chose" à une fonction.
Ainsi, la fonction "afficher quelque chose" sera passée en paramètre à la fonction forEach.
Les fonctions étant des variables et comme les variables peuvent être passées en paramètres, on peut passer "afficher quelque chose" à une fonction.
Ainsi, la fonction "afficher quelque chose" sera passée en paramètre à la fonction forEach.
Résumé des codes
Affichage
function affVal(v){ console.log(`val tab : ${v}`) }
Affichage Positif
function AffPositif(v){ if (v>0) console.log(` val positif : ${v} `); }
Boucle sur le tableau
function forEach(array, fx) { for (var i = 0; i < array.length; i++)//for of fx(array[i]); }
Appel
forEach(T, AffPositif);
Appel anonyme
forEach(T, function (v){ console.log(`-> tab : ${v}`);});
En Action
Affichage | function affVal(v){ console.log(`val tab : ${v}`) } |
Affichage Positif | function AffPositif(v){ if (v>0) console.log(` val positif : ${v} `); } |
Boucle sur le tableau | function forEach(array, fx) { for (var i = 0; i < array.length; i++)//for of fx(array[i]); } |
Appel | forEach(T, AffPositif); |
Appel anonyme | forEach(T, function (v){ console.log(`-> tab : ${v}`); }); |
En Action