Table des matières
Exemple
Méthode alternative
Maison interface Web js tutoriel Comment appeler une fonction à partir d'un nom de fonction stocké dans une chaîne en utilisant JavaScript ?

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

Aug 27, 2023 am 09:09 AM

如何使用 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!

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

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

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)

Remplacer les caractères de chaîne en javascript Remplacer les caractères de chaîne en javascript Mar 11, 2025 am 12:07 AM

Remplacer les caractères de chaîne en javascript

Tutoriel de configuration de l'API de recherche Google personnalisé Tutoriel de configuration de l'API de recherche Google personnalisé Mar 04, 2025 am 01:06 AM

Tutoriel de configuration de l'API de recherche Google personnalisé

Exemple Couleurs Fichier JSON Exemple Couleurs Fichier JSON Mar 03, 2025 am 12:35 AM

Exemple Couleurs Fichier JSON

10 Highlighters de syntaxe jQuery 10 Highlighters de syntaxe jQuery Mar 02, 2025 am 12:32 AM

10 Highlighters de syntaxe jQuery

8 Superbes plugins de mise en page JQuery Page 8 Superbes plugins de mise en page JQuery Page Mar 06, 2025 am 12:48 AM

8 Superbes plugins de mise en page JQuery Page

Créez vos propres applications Web Ajax Créez vos propres applications Web Ajax Mar 09, 2025 am 12:11 AM

Créez vos propres applications Web Ajax

Qu'est-ce que & # x27; ceci & # x27; en javascript? Qu'est-ce que & # x27; ceci & # x27; en javascript? Mar 04, 2025 am 01:15 AM

Qu'est-ce que & # x27; ceci & # x27; en javascript?

10 tutoriels JavaScript & jQuery MVC 10 tutoriels JavaScript & jQuery MVC Mar 02, 2025 am 01:16 AM

10 tutoriels JavaScript & jQuery MVC

See all articles