Table des matières
1 Clôture – la première expérience de l'amour
4 Résumé simple
Maison interface Web js tutoriel Exemple de code de fermeture JavaScript facile à comprendre

Exemple de code de fermeture JavaScript facile à comprendre

Mar 10, 2017 pm 03:16 PM

La fermeture est un concept propre à JavaScript. Pour les débutants, la fermeture est un concept particulièrement abstrait, notamment la définition donnée par la spécification ECMA, sans expérience pratique. comprenez-le à partir de la définition. Cet article ne décrira donc pas longuement le concept de fermeture, mais passera directement aux informations pratiques pour que vous puissiez apprendre la fermeture en quelques minutes !

1 Clôture – la première expérience de l'amour

Quand j'entre en contact avec une nouvelle technologie, la première chose que je fais est : la chercher démo code. Pour les codeurs, le code peut parfois mieux comprendre quelque chose que le langage naturel. En fait, les fermetures sont partout. Par exemple, les principaux codes de jQuery et de zepto sont tous inclus dans une grande fermeture. J'écrirai donc ci-dessous la démo de fermeture la plus simple et la plus primitive afin que vous puissiez générer des fermetures dans votre cerveau.

function A(){
    function B(){
       console.log("Hello Closure!");
    }
    return B;
}
var c = A();
c();//Hello Closure!
Copier après la connexion

C'est la fermeture la plus simple de l'histoire. Cela ne peut pas être plus simple. Si c'est plus simple, ce n'est plus une fermeture !

Après avoir eu une compréhension préliminaire, analysons brièvement en quoi elle diffère des fonctions ordinaires, afin que nous puissions la reconnaître d'un coup d'œil parmi la « foule immense ».

Le code ci-dessus est traduit en langage naturel comme suit :

(1) définit une fonction ordinaire A

(2) définit une fonction ordinaire B

< dans A 🎜>(3) Renvoie B dans A (pour être précis, renvoie une référence à B dans A)

(4) Exécute A() et attribue le résultat de retour de A à la variable c

(5) Exécuter c()

Pour résumer ces 5 étapes de fonctionnement en une phrase absurde :

La fonction interne B de la fonction A est référencée par une variable c extérieure à la fonction A

Retraitez cette absurdité et cela devient la définition de la fermeture :

Lorsqu'une fonction interne est référencée par une variable extérieure à sa fonction externe, une fermeture se forme.

Ne vous embêtez pas à vous souvenir de cette définition. Le but de vous donner cette définition est de vous faire comprendre que les 5 étapes ci-dessus visent à élaborer la définition de la fermeture.

Par conséquent, lorsque vous effectuez les 5 étapes ci-dessus, vous avez déjà défini une fermeture !

C'est la clôture.

2 Le rôle de la fermeture

Avant de comprendre le rôle de la fermeture, comprenons d'abord le mécanisme GC en javascript : En javascript, si un objet n'est plus référencé, alors cet objet Il le sera recyclé par GC, sinon cet objet sera toujours stocké en mémoire.

Dans l'exemple ci-dessus, B est défini dans A, donc B dépend de A, et la variable externe c fait référence à B, donc A est indirectement référencé par c, c'est-à-dire que A ne sera pas recyclé par GC , sera toujours sauvegardé en mémoire. Pour prouver notre raisonnement, l'exemple ci-dessus est légèrement amélioré :

function A(){
    var count = 0;
    function B(){
       count ++;
       console.log(count);
    }
    return B;
}
var c = A();
c();// 1
c();// 2
c();// 3
Copier après la connexion

count est une variable dans A et sa valeur est modifiée dans B , à chaque fois que la fonction B est exécuté, la valeur de count augmentera de 1 en fonction de la valeur d'origine. Par conséquent, le décompte dans A est toujours conservé en mémoire.

C'est le rôle de la fermeture. Parfois on a besoin de définir une telle variable dans un module : on espère que cette variable sera toujours sauvegardée en mémoire mais ne "polluera" pas la variable globale. nous pouvons utiliser des fermetures pour définir ce module.

3 méthodes d'écriture haut de gamme

La méthode d'écriture ci-dessus est en fait la méthode d'écriture la plus simple et la plus primitive, mais dans les applications réelles, personne ne le fait de cette façon, en particulier dans certains grands frameworks JS . Écrire. La raison pour laquelle je vous parle de cette façon d’écrire est que moins il y a de distractions, plus il est facile de se concentrer sur une chose. Ci-dessous, j'utilise la méthode d'écriture couramment utilisée pour écrire un composant de démonstration simple :

(function(document){
    var viewport;
    var obj = {
        init:function(id){
           viewport = document.querySelector("#"+id);
        },
        addChild:function(child){
            viewport.appendChild(child);
        },
        removeChild:function(child){
            viewport.removeChild(child);
        }
    }
    window.jView = obj;
})(document);
Copier après la connexion

La fonction de ce composant est d'initialiser un conteneur puis de l'ajouter au conteneur Ajoutez des sous-conteneurs et supprimez un conteneur. La fonction est très simple, mais un autre concept entre ici en jeu : exécuter la fonction immédiatement. Comprenez-le simplement brièvement. L'essentiel est de comprendre comment cette méthode d'écriture implémente la fonction de fermeture.

La structure de code ci-dessus peut être divisée en deux parties : (function(){})() La partie rouge est une expression, et cette expression elle-même est une fonction anonyme, donc ajouter (après cette expression) signifie exécuter cette fonction anonyme.

Le processus d'exécution de ce code peut donc se décomposer comme suit :

var f = function(document){
    var viewport;
    var obj = {
        init:function(id){
            viewport = document.querySelector("#"+id);
        },
        addChild:function(child){
            viewport.appendChild(child);
        },
        removeChild:function(child){
            viewport.removeChild(child);
        }
    }
    window.jView = obj;
};
f(document);
Copier après la connexion

Il semble que l'ombre de la fermeture soit visible dans ce code , mais il n'y a pas de valeur de retour dans f, et il semble qu'il ne remplisse pas les conditions de fermeture :

window.jView = obj;
Copier après la connexion

obj est défini dans f Un objet, cet objet définit une série de méthodes. Exécuter window.jView = obj signifie définir une variable jView dans l'objet global window et pointer cette variable vers l'objet obj, c'est-à-dire la variable globale à laquelle jView fait référence. vers obj.Et dans l'objet obj La fonction fait également référence à la variable viewport dans f, donc la viewport dans f ne sera pas recyclée par GC et sera enregistrée en mémoire, donc cette méthode d'écriture remplit les conditions de fermeture.

4 Résumé simple

C'est la compréhension la plus simple des fermetures. Bien sûr, les fermetures ont une compréhension plus profonde, qui est plus impliquée. Vous devez comprendre l'environnement d'exécution de JS (contexte d'exécution), les objets actifs. (objets d'appel) et les mécanismes de fonctionnement des portées et des chaînes de portées. Mais en tant que débutant, vous n'avez pas besoin de les comprendre pour le moment. Après avoir une compréhension simple, vous devez l'utiliser dans des projets réels. Lorsque vous l'utiliserez davantage, vous aurez naturellement une compréhension plus profonde des fermetures !

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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Quelle est la signification de la fermeture dans l'expression lambda C++ ? Quelle est la signification de la fermeture dans l'expression lambda C++ ? Apr 17, 2024 pm 06:15 PM

En C++, une fermeture est une expression lambda qui peut accéder à des variables externes. Pour créer une fermeture, capturez la variable externe dans l'expression lambda. Les fermetures offrent des avantages tels que la réutilisabilité, la dissimulation des informations et une évaluation paresseuse. Ils sont utiles dans des situations réelles telles que les gestionnaires d'événements, où la fermeture peut toujours accéder aux variables externes même si elles sont détruites.

Quels sont les avantages et les inconvénients des fermetures dans les fonctions C++ ? Quels sont les avantages et les inconvénients des fermetures dans les fonctions C++ ? Apr 25, 2024 pm 01:33 PM

Une fermeture est une fonction imbriquée qui peut accéder aux variables dans la portée de la fonction externe. Ses avantages incluent l'encapsulation des données, la conservation de l'état et la flexibilité. Les inconvénients incluent la consommation de mémoire, l’impact sur les performances et la complexité du débogage. De plus, les fermetures peuvent créer des fonctions anonymes et les transmettre à d'autres fonctions sous forme de rappels ou d'arguments.

Comment implémenter la fermeture dans une expression C++ Lambda ? Comment implémenter la fermeture dans une expression C++ Lambda ? Jun 01, 2024 pm 05:50 PM

Les expressions C++ Lambda prennent en charge les fermetures, qui enregistrent les variables de portée de fonction et les rendent accessibles aux fonctions. La syntaxe est [capture-list](parameters)->return-type{function-body}. capture-list définit les variables à capturer. Vous pouvez utiliser [=] pour capturer toutes les variables locales par valeur, [&] pour capturer toutes les variables locales par référence, ou [variable1, variable2,...] pour capturer des variables spécifiques. Les expressions Lambda ne peuvent accéder qu'aux variables capturées mais ne peuvent pas modifier la valeur d'origine.

Résoudre le problème de fuite de mémoire causé par les fermetures Résoudre le problème de fuite de mémoire causé par les fermetures Feb 18, 2024 pm 03:20 PM

Titre : Fuites de mémoire causées par les fermetures et solutions Introduction : Les fermetures sont un concept très courant en JavaScript, qui permettent aux fonctions internes d'accéder aux variables des fonctions externes. Cependant, les fermetures peuvent provoquer des fuites de mémoire si elles ne sont pas utilisées correctement. Cet article explorera le problème de fuite de mémoire provoqué par les fermetures et fournira des solutions et des exemples de code spécifiques. 1. Fuites de mémoire causées par les fermetures La caractéristique des fermetures est que les fonctions internes peuvent accéder aux variables des fonctions externes, ce qui signifie que les variables référencées dans les fermetures ne seront pas récupérées. S'il est mal utilisé,

L'impact des pointeurs de fonction et des fermetures sur les performances de Golang L'impact des pointeurs de fonction et des fermetures sur les performances de Golang Apr 15, 2024 am 10:36 AM

L'impact des pointeurs de fonction et des fermetures sur les performances de Go est le suivant : Pointeurs de fonction : légèrement plus lents que les appels directs, mais améliorent la lisibilité et la réutilisabilité. Fermetures : généralement plus lentes, mais encapsulent les données et le comportement. Cas pratique : les pointeurs de fonction peuvent optimiser les algorithmes de tri et les fermetures peuvent créer des gestionnaires d'événements, mais ils entraîneront des pertes de performances.

Comment les fermetures sont-elles implémentées en Java ? Comment les fermetures sont-elles implémentées en Java ? May 03, 2024 pm 12:48 PM

Les fermetures en Java permettent aux fonctions internes d'accéder aux variables de portée externe même si la fonction externe est terminée. Implémentée via des classes internes anonymes, la classe interne contient une référence à la classe externe et maintient les variables externes actives. Les fermetures augmentent la flexibilité du code, mais vous devez être conscient du risque de fuite de mémoire, car les références à des variables externes par des classes internes anonymes maintiennent ces variables en vie.

Appels enchaînés et fermetures de fonctions PHP Appels enchaînés et fermetures de fonctions PHP Apr 13, 2024 am 11:18 AM

Oui, la simplicité et la lisibilité du code peuvent être optimisées grâce à des appels et des fermetures enchaînés : les appels en chaîne lient les appels de fonction dans une interface fluide. Les fermetures créent des blocs de code réutilisables et accèdent à des variables en dehors des fonctions.

Le rôle de la fermeture de la fonction Golang dans les tests Le rôle de la fermeture de la fonction Golang dans les tests Apr 24, 2024 am 08:54 AM

Les fermetures de fonctions du langage Go jouent un rôle essentiel dans les tests unitaires : Capture de valeurs : les fermetures peuvent accéder aux variables dans la portée externe, permettant ainsi de capturer et de réutiliser les paramètres de test dans des fonctions imbriquées. Simplifiez le code de test : en capturant les valeurs, les fermetures simplifient le code de test en éliminant le besoin de définir des paramètres à plusieurs reprises pour chaque boucle. Améliorez la lisibilité : utilisez des fermetures pour organiser la logique de test, rendant ainsi le code de test plus clair et plus facile à lire.

See all articles