Maison > interface Web > js tutoriel > Pouvez-vous accéder à la fermeture d'une fonction par programme en JavaScript ?

Pouvez-vous accéder à la fermeture d'une fonction par programme en JavaScript ?

Patricia Arquette
Libérer: 2024-10-29 22:10:03
original
960 Les gens l'ont consulté

Can You Access a Function's Closure Programmatically in JavaScript?

Accès à la fermeture d'une fonction

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>
Copier après la connexion

Le but est d'accéder à la variable y à l'aide de la fonction x.

Accès à la fermeture

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>
Copier après la connexion

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!

source:php.cn
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