Maison > interface Web > js tutoriel > le corps du texte

Comment accéder aux variables externes dans les boucles à partir des fermetures JavaScript ?

Patricia Arquette
Libérer: 2024-10-20 08:57:31
original
814 Les gens l'ont consulté

How to Access Outside Variables in Loops from JavaScript Closures?

Accéder à une variable extérieure dans une boucle à partir de la fermeture JavaScript

Le problème survient lors de l'accès aux variables déclarées dans une boucle, en particulier lorsque ces variables sont référencées ultérieurement dans un rappel asynchrone. Pour illustrer, considérons l'extrait de code suivant :

<code class="javascript">for (var i in this.items) {
    var item = this.items[i];
    // ...
}</code>
Copier après la connexion

Dans ce cas, la variable item changera à chaque itération de boucle. Lorsque l'élément est référencé ultérieurement, il conservera la valeur du dernier élément du tableau.

Solution : utiliser des fermetures

Une solution à ce problème consiste à utiliser des fermetures, qui créent des fonctions qui renvoient d'autres fonctions. En utilisant des fermetures, la variable item peut avoir une portée différente, comme indiqué ci-dessous :

<code class="javascript">for (var i in this.items) {
    var item = this.items[i];
    // ...
    $("#showcasebutton_"+item.id).click(
        (function(item) {
            return function() {
                alert(item.id);
                self.switchto(item.id);
            };
        })(item)
    );
}</code>
Copier après la connexion

Alternative : l'aide $.each() de jQuery

Si jQuery est disponible , l'assistant $.each() peut être utilisé comme raccourci pour de simples boucles for/each. Il atténue le besoin de fermetures en raison de la façon dont la portée fonctionne dans ses appels de fonction :

<code class="javascript">$.each(this.items,function(i, item) {
    // ...
    $("#showcasebutton_"+item.id).click(function() {
        alert(item.id);
        self.switchto(item.id);
    });
});</code>
Copier après la connexion

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!

source:php
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!