Maison >interface Web >js tutoriel >À propos de la méthode itérateur js
Un itérateur est un objet qui peut être utilisé pour parcourir tout ou partie des éléments dans un conteneur de bibliothèque de modèles standard. Chaque objet itérateur représente une certaine adresse dans le conteneur. Il existe deux types de méthodes itératives pour les tableaux js : l'une ne génère pas de nouveau tableau et l'autre génère un nouveau tableau.
La première méthode : ne produit aucun nouveau tableau, mais effectue une opération sur chaque élément du tableau ou renvoie une valeur.
1. Méthode forEach(), qui reçoit une fonction en paramètre et utilise la fonction pour chaque élément du tableau.
<script> function arr(num){console.log(num+1)}; var array = [1,2,3,4,5,6]; array.forEach(arr); </script>
2. Every() et some(), les deux méthodes acceptent une fonction dont la valeur de retour est de type booléen et utilisent cette fonction pour chaque élément du tableau. La méthode Every() renvoie true si la fonction renvoie true pour tous les éléments. La méthode some() renvoie true tant qu'un élément utilise cette fonction pour renvoyer true.
<script> var arr = [1,3,4,5,6,7,8]; function even(num){return num%2 ==0}; var sum = arr.every(even); var nums = arr.some(even); console.log(sum)//false; console.log(nums)//true;
</script>
3. La méthode réduire() accepte une fonction et renvoie une valeur. Cette méthode commencera par une valeur accumulée, continuera à appeler la fonction sur la valeur accumulée et les éléments suivants du tableau, jusqu'au dernier élément du tableau, et retournera enfin la valeur accumulée. Vous pouvez également concaténer les éléments du tableau de chaînes en une longue chaîne
function add(total,num){return total+-*/num}; var arr =[1,2,3,4]; var sum = arr.reduce(add);
js fournit également la méthode réduireRight(), la différence est qu'elle est en séquence avec la méthode réduire () Exactement le contraire, de droite à gauche.
La deuxième méthode est une méthode itératrice qui génère un nouveau tableau
Il existe deux méthodes itératrices qui peuvent générer un nouveau tableau : map() et filter(). map() est un peu comme forEach(), qui utilise une fonction sur chaque élément du tableau. La différence entre les deux est que map() renvoie un nouveau tableau, qui est le résultat de l'application d'une fonction aux éléments d'origine.
function add(num) { return num+=5; } var words =[1,2,3,4,5]; var sum =words.map(add); console.log(sum);//[6,7,8,9,10]
filter() est similaire à each(), en passant une fonction dont la valeur de retour est un type booléen. La différence avec each() est que lorsque le. array is Lorsque la fonction est appliquée à tous les éléments et que les résultats sont vrais, cette méthode ne renvoie pas vrai, mais renvoie un nouveau tableau contenant les éléments pour lesquels la fonction est vraie.
function add(num) { return num%2 == 0; } var words =[1,2,3,4,5]; var sum =words.filter(add); console.log(sum);//[2,4];
<br/>
filter() peut également être utilisé pour filtrer des tableaux de chaînes. Par exemple :
function add(str){if(str).indexOf("cie")>-1){return true;}return false;} var words =["recieve","deceit","deceive"] var miss = words.filter(add); console.log(miss)//["recieve"]
Le contenu ci-dessus concerne la méthode de l'itérateur js, j'espère qu'il pourra aider tout le monde.
Recommandations associées :
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!