--- title: function slug: Web/JavaScript/Reference/Statements/function tags: - JavaScript - Reference - Statement translation_of: Web/JavaScript/Reference/Statements/function original_slug: Web/JavaScript/Reference/Instructions/function ---
La déclaration function
(ou l'instruction function
) permet de définir une fonction et les paramètres que celle-ci utilise.
Le code source de cet exemple interactif est disponible dans un dépôt GitHub. Si vous souhaitez contribuez à ces exemples, n'hésitez pas à cloner https://github.com/mdn/interactive-examples et à envoyer une pull request !
Il est également possible de définir des fonctions en utilisant le constructeur {{jsxref("Function")}} et une {{jsxref("Opérateurs/L_opérateur_function", "expression de fonction","",1)}}.
function nom([param1[, param2,[..., paramN]]]) { [instructions] }
nom
param
Ninstructions
Une fonction créée via une déclaration de fonction est un objet Function
et possède toutes les caractéristiques (propriétés, méthodes et comportement) d'un objet Function
. Voir la page {{jsxref("Function")}} pour plus d'informations sur ces caractéristiques.
Une fonction peut également être créée en utilisant une expression (voir {{jsxref("Opérateurs/L_opérateur_function", "les expressions de fonctions","",1)}}).
Par défaut, une fonction renvoie {{jsxref("undefined")}}. Pour renvoyer une autre valeur en résultat, une fonction doit utiliser une instruction {{jsxref("Instructions/return", "return")}} qui définit la valeur à retourner.
Il est possible de déclarer des fonctions de façon conditionnelle (c'est-à-dire qu'on peut placer une instruction de déclaration de fonction au sein d'une instruction if
). La plupart des navigateurs, autres que ceux basés sur Gecko, traiteront cette déclaration conditionnelle comme si elle était inconditionnelle (que la condition souhaitée soit vérifiée ou non) (voir cet article (en anglais) pour un aperçu). Pour cette raison, les déclarations de fonctions ne devraient pas être utilisées pour créer des fonctions de façon conditionnelle. Pour ce faire, il faut privilégier les expressions de fonctions.
var remontee = "toto" in this; console.log(`'toto' ${remontee ? "est" : "n'est pas"} remontée. typeof toto vaut ${typeof toto}`); if (false) { function toto(){ return 1; } } // Pour Chrome: // 'toto' est remontée. typeof toto vaut undefined // // Pour Firefox: // 'toto' est remontée. typeof toto vaut undefined // // Pour Edge: // 'toto' n'est pas remontée. typeof toto vaut undefined // // Pour Safari: // 'toto' est remontée. typeof toto vaut function
On obtient exactement les mêmes résultats si la condition est vérifiée (ici avec true
) :
var remontee = "toto" in this; console.log(`'toto' ${remontee ? "est" : "n'est pas"} remontée. typeof toto vaut ${typeof toto}`); if (true) { function toto(){ return 1; } } // Pour Chrome: // 'toto' est remontée. typeof toto vaut undefined // // Pour Firefox: // 'toto' est remontée. typeof toto vaut undefined // // Pour Edge: // 'toto' n'est pas remontée. typeof toto vaut undefined // // Pour Safari: // 'toto' est remontée. typeof toto vaut function
Lorsqu'on utilise une déclaration de fonction pour créer une fonction, la définition de la fonction est « remontée ». Il devient donc possible d'utiliser la fonction avant de l'avoir déclarée :
remontée(); // affiche "toto" dans la console function remontée() { console.log("toto"); }
On notera que les {{jsxref("Opérateurs/L_opérateur_function", "expressions de fonctions","",1)}} ne sont pas remontées :
nonRemontée(); // TypeError: nonRemontée is not a function var nonRemontée = function() { console.log("truc"); };
function
Dans l'exemple qui suit, on déclare une fonction qui renvoie le total des ventes en fonction des nombres d'unités vendues pour les produits a
, b
, et c
.
function calc_ventes(nb_produits_a, nb_produits_b, nb_produits_c) { return nb_produits_a*79 + nb_produits_b * 129 + nb_produits_c * 699; }
Spécification | État | Commentaires |
---|---|---|
{{SpecName('ESDraft', '#sec-function-definitions', 'Function definitions')}} | {{Spec2('ESDraft')}} | |
{{SpecName('ES6', '#sec-function-definitions', 'Définition de fonction')}} | {{Spec2('ES6')}} | |
{{SpecName('ES5.1', '#sec-13', 'Définition de fonction')}} | {{Spec2('ES5.1')}} | |
{{SpecName('ES3', '#sec-13', 'Définition de fonction')}} | {{Spec2('ES3')}} | |
{{SpecName('ES1', '#sec-13', 'Définition de fonction')}} | {{Spec2('ES1')}} | Définition initiale. Implémentée avec JavaScript 1.0. |
{{Compat("javascript.statements.function")}}
async function
(les déclarations des fonctions asynchrones)async function
(les expressions de fonctions asynchrones)