


Comment les fonctions de fermeture JavaScript accèdent aux variables externes_conseils javascript
Une fermeture fait référence à une fonction qui a le droit d'accéder aux variables dans la portée d'une autre fonction. Cependant, il y a une chose à noter concernant le mécanisme de configuration de la portée, c'est-à-dire que la fermeture ne peut obtenir que la dernière valeur de n'importe quelle. variable dans la fonction contenant.
Comme le cas suivant :
function create(){ var arr = new Array(); for (var i=0; i<10; i++){ arr[i] = function(){ return i; }; } return arr; } var c_arr = create(); for(var i=0; i<c_arr.length;i++){ document.write("c_arr["+i+"] = "+c_arr[i]()+"<br />"); }
Résultat de l'exécution :
En apparence, il semble que la valeur i renvoyée par chaque fonction soit différente. Par exemple, la valeur de c_arr[0] devrait être 0, la valeur de c_arr[1] devrait être 1, et ainsi de suite. En conséquence, chaque fonction renvoie 10. Pourquoi?
Étant donné que l'objet actif de la fonction create() est stocké dans la chaîne de portée de chaque fonction, ils font tous référence à la même variable i. Lorsque la boucle for se termine, la valeur de i devient 10. À ce stade, chaque fonction fait référence au même objet variable qui contient la variable i.
On peut forcer la fermeture à se comporter comme prévu en créant une autre fonction de nom de domaine afin que chaque position corresponde à la valeur correspondante.
function create(){ var arr = new Array(); for (var i=0; i<10; i++){ arr[i] = function(num){ return function(){ return num; }; }(i); } return arr; } var c_arr = create(); for(var i=0; i<c_arr.length;i++){ document.write("c_arr["+i+"] = "+c_arr[i]()+"<br />"); }
Résultat de l'exécution :
Une fonction anonyme est définie et le mécanisme d'exécution de la fonction anonyme est immédiatement attribué au tableau. La fonction anonyme a ici un paramètre num, qui est la valeur à renvoyer par la fonction finale. Nous passons la variable i lors de l'appel de chaque fonction. Puisque les paramètres de fonction sont transmis par valeur, la valeur actuelle de la variable i sera affectée au paramètre num. À l'intérieur de cette fonction anonyme, une fermeture qui accède à num est créée et renvoyée. De cette façon, chaque fonction du tableau arr possède une copie de sa propre variable num, elle peut donc renvoyer des valeurs différentes.
Exemple classique
Regardons à nouveau un exemple classique. Supposons que la page comporte un ensemble de balises de bouton. Nous utilisons un script pour lier les événements de clic à cet ensemble de balises de bouton, et lorsque vous cliquez dessus, quel nombre de balises apparaîtront.
<meta charset="utf-8" /> <button>第一个</button> <button>第二个</button> <button>第三个</button> <button>第四个</button> <script type="text/javascript"> var obj = document.getElementsByTagName('button'); for(var i=0;i<obj.length;i++){ obj[i].onclick = function(){ alert(i); }; } </script>
Cliquez sur chaque bouton résultat
En apparence, il semble que cliquer sur chaque étiquette devrait faire apparaître un numéro différent
Le premier devrait apparaître avec 0 ;
Le deuxième devrait apparaître avec 1 ;
Et ainsi de suite.
Mais le résultat est que tous les boutons apparaissent 4, ce qui n'est évidemment pas le résultat que nous souhaitons.
Changeons de programme
<meta charset="utf-8" /> <button>第一个</button> <button>第二个</button> <button>第三个</button> <button>第四个</button> <script type="text/javascript"> var obj = document.getElementsByTagName('button'); for(var i=0;i<obj.length;i++){ obj[i].onclick = function(num){ return function(){ alert(num); } }(i); } </script>
Cliquez sur le deuxième
Cliquez sur le quatrième
Il suffit de créer une fonction anonyme au sein de la fonction, comme dans le cas ci-dessus. Vous pouvez implémenter une fonction anonyme pour capturer la variable externe i. Par conséquent, la valeur i de chaque bombe bouton est différente.

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Explication détaillée de la méthode de remplacement de la chaîne JavaScript et de la FAQ Cet article explorera deux façons de remplacer les caractères de chaîne dans JavaScript: le code JavaScript interne et le HTML interne pour les pages Web. Remplacer la chaîne dans le code JavaScript Le moyen le plus direct consiste à utiliser la méthode Remplace (): str = str.replace ("trouver", "remplacer"); Cette méthode remplace uniquement la première correspondance. Pour remplacer toutes les correspondances, utilisez une expression régulière et ajoutez le drapeau global G: str = str.replace (/ fi

Tirez parti de jQuery pour les dispositions de page Web sans effort: 8 plugins essentiels JQuery simplifie considérablement la mise en page de la page Web. Cet article met en évidence huit puissants plugins jQuery qui rationalisent le processus, particulièrement utile pour la création de sites Web manuels

Vous voici donc, prêt à tout savoir sur cette chose appelée Ajax. Mais qu'est-ce que c'est exactement? Le terme Ajax fait référence à un regroupement lâche de technologies utilisées pour créer un contenu Web interactif dynamique. Le terme Ajax, inventé à l'origine par Jesse J

10 plugins de jeu JQuery amusants pour rendre votre site Web plus attrayant et améliorer l'adhérence des utilisateurs! Bien que Flash soit toujours le meilleur logiciel pour développer des jeux Web occasionnels, JQuery peut également créer des effets surprenants, et bien qu'il ne soit pas comparable aux jeux Flash Pure Action, dans certains cas, vous pouvez également vous amuser inattendu dans votre navigateur. jeu jquery tic toe Le "Hello World" de la programmation de jeux a désormais une version jQuery. Code source JQUERY Crazy Word Composition Game Il s'agit d'un jeu de remplissage, et il peut produire des résultats étranges en raison de ne pas connaître le contexte du mot. Code source Jeu de balayage de la mine jQuery

L'article discute de la création, de la publication et du maintien des bibliothèques JavaScript, en se concentrant sur la planification, le développement, les tests, la documentation et les stratégies de promotion.

Ce tutoriel montre comment créer un effet de fond de parallaxe captivant à l'aide de jQuery. Nous allons construire une bannière d'en-tête avec des images en couches qui créent une profondeur visuelle étonnante. Le plugin mis à jour fonctionne avec jQuery 1.6.4 et plus tard. Télécharger le

Ce didacticiel montre la création de boîtes de page dynamiques chargées via AJAX, permettant un actualisation instantanée sans rechargement de page pleine. Il exploite JQuery et JavaScript. Considérez-le comme un chargeur de boîtes de contenu de style Facebook personnalisé. Concepts clés: Ajax et jQuery

Cette bibliothèque JavaScript exploite la propriété Window.Name pour gérer les données de session sans compter sur les cookies. Il offre une solution robuste pour stocker et récupérer des variables de session à travers les navigateurs. La bibliothèque fournit trois méthodes de base: Session
