Maison > interface Web > js tutoriel > Quel est l'impact des guillemets et des parenthèses sur l'exécution de « setTimeout » en JavaScript ?

Quel est l'impact des guillemets et des parenthèses sur l'exécution de « setTimeout » en JavaScript ?

Patricia Arquette
Libérer: 2024-11-17 19:08:02
original
377 Les gens l'ont consulté

How Do Quotes and Parentheses Impact `setTimeout` Execution in JavaScript?

Les subtilités de setTimeout : exploration des citations, des parenthèses et de l'exécution

Dans le domaine des événements de timing JavaScript, l'utilisation de setTimeout soulève souvent des questions. L'un de ces aspects est la syntaxe variable impliquant des guillemets et des parenthèses.

setTimeout avec parenthèses

Lorsque vous utilisez des parenthèses avec setTimeout, comme dans :

setTimeout(alertMsg, 3000);
Copier après la connexion
Copier après la connexion

vous transmettez un référence de fonction comme premier argument. Cela fonctionne car en JavaScript, les fonctions sont des citoyens de première classe, ce qui signifie qu'elles peuvent être transmises comme n'importe quelle autre valeur.

setTimeout sans guillemets ni parenthèses

La syntaxe sans guillemets ni parenthèses :

setTimeout(alertMsg, 3000);
Copier après la connexion
Copier après la connexion

est similaire au précédent. Cependant, dans ce cas, vous copiez la référence de la fonction. Au lieu de transmettre une référence à la fonction elle-même, vous fournissez une copie de la définition de cette fonction.

setTimeout avec des guillemets et des parenthèses

Utilisation des les deux guillemets et parenthèses, comme :

setTimeout("alertMsg()", 3000);
Copier après la connexion

est fortement déconseillé. Cette syntaxe est un vestige des premières versions de JavaScript et est sujette à des failles de sécurité. Il tente d'exécuter la chaîne "alertMsg()" sous forme de code, ce qui pourrait entraîner des conséquences inattendues.

La pratique recommandée

Pour éviter toute confusion et garantir la sécurité, l'approche recommandée est de toujours utiliser setTimeout comme suit :

setTimeout(functionName, delay);
Copier après la connexion

où functionName est le nom de la fonction que vous souhaitez exécuter et delay est le temps en millisecondes après lequel la fonction sera appelée. Cette syntaxe garantit la clarté, évite les risques de sécurité potentiels et assure la compatibilité entre différents environnements JavaScript.

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