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

Comment appeler une fonction à partir d'un nom de fonction stocké dans une chaîne en utilisant JavaScript ?

王林
Libérer: 2023-08-27 09:09:11
avant
1000 Les gens l'ont consulté

如何使用 JavaScript 从存储在字符串中的函数名称调用函数?

Nous utiliserons la fonction eval() pour appeler une fonction à partir de son nom stocké dans une chaîne. Évaluer() La fonction évalue une chaîne en code JavaScript. Cela nous permet d'appeler la fonction via Passez une chaîne contenant son nom comme argument à la fonction eval().

Exemple

Voici un exemple fonctionnel complet de la façon d'appeler une fonction à partir d'un nom de fonction stocké dans une chaîne à l'aide de JavaScript -

// Define the function that we want to call function sayHello() { console.log("Hello, world!"); } // Store the function name as a string let functionName = "sayHello"; // Use the `eval()` function to convert the string to a function call eval(functionName + "()");
Copier après la connexion
  • Dans l'exemple ci-dessus, nous définissons d'abord une fonction simple appelée sayHello(), qui enregistre simplement « Hello, world ! » sur la console. Ensuite, nous définissons une variable appelée functionName qui stocke la chaîne "sayHello", qui est le nom de la fonction que nous voulons appeler.

  • Enfin, nous utilisons la fonction eval() pour convertir la chaîne functionName en un appel de fonction en la concaténant avec les crochets () requis pour appeler réellement la fonction.

  • La fonction
  • eval() est une fonctionnalité puissante mais potentiellement dangereuse de JavaScript qui vous permet d'évaluer des chaînes tout comme le code JavaScript. L'utilisation de eval() dans le code de production n'est généralement pas recommandée car elle peut être utilisée pour exécuter du code arbitraire, ce qui peut constituer un risque pour la sécurité.

Méthode alternative

Il convient de mentionner qu'il existe des moyens plus sûrs d'appeler une fonction à partir de son nom stocké dans une chaîne sans utiliser eval, comme -

let functionName = "sayHello"; let functionObj = window[functionName]; functionObj();
Copier après la connexion

ou

let functionName = "sayHello"; let functionObj = window['sayHello']; functionObj();
Copier après la connexion

Ces alternatives sont plus sûres que l'utilisation de eval car elles n'exécutent pas de code arbitraire mais font référence à la fonction directement par son nom.

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:tutorialspoint.com
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 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!