En JavaScript, les fonctions forment des fermetures en conservant un lien caché vers leur portée englobante. Cela soulève la question : est-il possible d'accéder à cette fermeture par programme lorsque la fonction est disponible en tant que valeur variable ?
La motivation principale derrière cette enquête est théorique, mais une application pratique pourrait impliquer de répertorier les propriétés de la fermeture. . Considérons le code suivant :
<code class="js">var x = (function(){ var y = 5; return function() { alert(y); }; })(); //access y here with x somehow</code>
Le but est d'accéder à la variable y à l'aide de la fonction x.
Dans les environnements frontend, où vous pouvez exécuter votre JavaScript dans une balise de script précédente, une approche consiste à attacher un MutationObserver. Cet observateur attend que la balise de script que vous souhaitez examiner (x dans ce cas) soit insérée dans le document et modifie son code pour exposer la fonctionnalité souhaitée.
Par exemple :
<code class="js">new MutationObserver((mutations, observer) => { // Find the target script tag const tamperTarget = document.querySelector('script + script'); if (!tamperTarget) { return; } observer.disconnect(); console.log('Target script getting tampered with'); // Modify the script's content to expose the closure tamperTarget.textContent = tamperTarget.textContent.replace( 'return function', 'window.y = y; return function' ); setTimeout(() => { console.log("Hacked into tamper target's script and found a y of", y); console.log('Could also have replaced the local y with another value'); }); }) .observe(document.body, { childList: true });</code>
Ce script attache l'observateur au document.body. Lorsque la balise de script contenant la fonction x est insérée, l'observateur déclenche et remplace la fonction de retour de ligne par window.y = y ; fonction de retour. Cela expose la variable y en tant que variable globale (window.y).
Par la suite, vous pouvez accéder et manipuler la variable y comme vous le souhaitez. Cette technique peut être utile pour le débogage, les tests et l'expérimentation 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!