Les fermetures ne sont pas propres à JavaScript, la plupart des langages de haut niveau ont cette capacité.
Une fermeture est la combinaison d'une fonction regroupée (enfermée) avec des références à son état environnant (l'environnement lexical).
ce Segment est la définition de la fermeture sur MDN, qui s'entend comme : une fonction et ses références environnantes dans l'environnement lexical fermé constituent une fermeture. Peut-être que cette phrase est encore difficile à comprendre. Jetez un œil à l'exemple :
function createAction() { var message = "封闭环境内的变量"; return function() { console.log(message); } } const showMessage = createAction(); showMessage(); // output: 封闭环境内的变量
Cet exemple est une fermeture typique. Il y a plusieurs points à noter :
showMessage
Oui. 🎜> Une createAction
fonction en est renvoyée après exécution.
createAction
, en tant que variable au sein de cet environnement encapsulé, n'est jamais directement accessible de l'extérieur. message
showMessage
, mais la variable locale createAction
définie à l'intérieur est accessible pendant l'exécution (sortie réussie). En effet, la fonction référencée par message
(la fonction anonyme à l'intérieur de showMessage
), lorsqu'elle est définie, est liée aux références (createAction
, etc.) dans l'environnement lexical (à l'intérieur de createAction
) où elle se trouve . message
return
fermé, qui forme une fermeture. S'il est appelé à l'intérieur de createAction
, cela n'est pas considéré comme une fermeture. createAction
ne pensez pas que « vous » avez créé la fermeture, car les fermetures sont une fonctionnalité du langage, vous venez de profiter de cette fonctionnalité .
Si le langage ne prend pas en charge les fermetures, similaires au code ci-dessus, lorsque est exécuté, la variable showMessage
ne sera pas trouvée. Je veux surtout trouver un exemple, mais malheureusement, tous les langages de haut niveau que je connais semblent prendre en charge les fermetures tant que les fonctions peuvent être définies dans les fonctions/méthodes. message
Existe-t-il un autre moyen ? return
function encase(aCase) { const dog = "狗狗"; const cat = "猫猫"; aCase.show = function () { console.log(dog, cat); }; } const myCase = {}; encase(myCase); myCase.show(); // output: 猫猫 狗狗
pour amener les marchandises une par une, ou vous pouvez utiliser exports.something
pour emballer les marchandises, mais quoi qu'il en soit, module.exports = ...
est celui qui apporte les marchandises, mais il se peut que le exports
initialement prévu ait été remplacé par l'un des nôtres exports
. exports
et import
, qui n'est qu'une autre façon de faire ressortir les marchandises. C'est presque la même chose que export
. seulement Vous pouvez en apporter un (sauf si emballé), return
vous pouvez en apporter un tas. return
export
Il faut ajouter que qu'il s'agisse de CJS ou d'ESM, le module est un environnement encapsulé, et les éléments qui y sont définis ne sont pas accessibles de l'extérieur tant qu'ils ne sont pas retirés. Ceci est différent de l'environnement global par défaut des scripts Web. Veuillez faire attention à la différence.
Si exprimé en code, c'est probablement ce que je pensais lors de la définition du module :
const var1 = "我是一个顶层变量吧"; function maybeATopFunction() { }
Dans l'environnement d'exécution, cela ressemble en réalité à ceci (note : uniquement à titre d'illustration) :
// module factory function createModule_18abk2(exports, module) { const var1 = "我是一个顶层变量吧"; function maybeATopFunction() { } } // ... 遥远的生产线上,有这样的示意代码 const module = { exports: {} }; const m18abk2 = createModule_18abk2(module) ?? module; // 想明白 createModule_18abk2 为什么会有一个随机后缀没?
C'est toujours la même fonction ?
Essayez :
function create() { function closure() { } return closure; } const a = create(); const b = create(); console.log(a === b); // false
Si vous êtes surpris, alors définissez
d'une autre manière pour voir si ce sera plus facile à comprendre :function create() { closure = function() { } return closure; }
closure()
Si vous pouvez toujours' Je n'ai pas compris, réessayez. Regardez ceci : function create() { const a = function () { }; const b = function () { }; console.log(a === b); // false }
Comprenez-vous ? À chaque fois,
définit une nouvelle fonction. La fonction est nouvelle et le nom n'a pas d'importance - vous pouvez l'appeler Xiao Ming, mais d'autres peuvent aussi l'appeler Xiao Ming.function
Donc, pour résumer :
Clôture, j'ai compris cette fois-ci !
Tutoriel recommandé : "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!