Movatterモバイル変換


[0]ホーム

URL:


  1. Web
  2. JavaScript
  3. Référence
  4. Objets natifs standards
  5. Function
  6. Function.name

Cette page a été traduite à partir de l'anglais par la communauté.Vous pouvez contribuer en rejoignant la communauté francophone sur MDN Web Docs.

View in EnglishAlways switch to English

Function.name

Baseline Widely available

Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis ⁨août 2016⁩.

La propriétéfunction.name est une propriété en lecture seule qui renvoie le nom de la fonction courante ou"anonymous" si celle-ci a été créée de façon anonyme.

Exemple interactif

const func1 = function () {};const object = {  func2: function () {},};console.log(func1.name);// Expected output: "func1"console.log(object.func2.name);// Expected output: "func2"
Attributs deFunction.name
ÉcrivableNon
ÉnumérableNon
ConfigurableOui

Note :Dans les implémentations non-standards antérieures à ES2015, l'attributconfigurable valaitfalse.

Exemples

Instruction de fonction

La propriéténame renvoie le nom de la fonction lorsque celle-ci est utilisée dans une instruction de fonction.

js
function faireUnTruc() {}faireUnTruc.name; // "faireUnTruc"

Fonctions créées avec un constructeur

Lorsqu'on crée une fonction avecnew Function(...) ou simplementFunction(...), on crée uniquement des objets dont le nom est "anonymous".

js
new Function().name; // "anonymous"

Inférence des noms de fonction

Les variables et les méthodes permettent d'inférer (c'est-à-dire de « deviner ») le nom des fonctions anonymes en fonction de leur position syntaxique (cette fonctionnalité est apparue avec ECMAScript 2015).

js
var f = function () {};var objet = {  uneMéthode: function () {},};console.log(f.name); // "f"console.log(objet.uneMéthode.name); // "uneMéthode"

On peut définir une fonction avec un nom grâce à uneexpression de fonction:

js
var objet = {  uneMéthode: function objet_maMéthode() {},};console.log(objet.uneMéthode.name); // logs "objet_maMéthode"try {  objet_maMéthode;} catch (e) {  console.log(e);}// ReferenceError: objet_maMéthode is not defined

On ne peut pas changer le nom d'une fonction, cette propriété est uniquement en lecture :

js
var objet = {  // anonyme  uneMéthode: function () {},};objet.uneMéthode.name = "uneMéthode";console.log(object.uneMéthode.name); // une chaîne vide, uneMéthode est anonyme

Pour modifier le nom, on pourrait cependant utiliser la méthodeObject.defineProperty().

Notation raccourcie pour les méthodes

js
var o = {  toto() {},};o.toto.name; // "toto";

Noms des fonctions liées

Function.bind() produit une fonction dont le nom sera la chaîne "bound " suivi du nom de la fonction.

js
function toto() {}toto.bind({}).name; // "bound toto"

Noms de fonction pour les accesseurs et les mutateurs

Lorsqu'on utilise les propriétés d'accesseurget /set, "get" ou "set" apparaîtra avant le nom de la fonction.

js
var o = {  get toto() {},  set toto(x) {},};var descripteur = Object.getOwnPropertyDescriptor(o, "toto");descripteur.get.name; // "get toto"descripteur.set.name; // "set toto";

Noms des fonctions utilisées dans les classes

On peut utiliser la notationobj.constructor.name pour vérifier la « classe » d'un objet (attention aux avertissements ci-après) :

js
function Toto() {} // Syntaxe ES2015 : class Toto {}var instanceDeToto = new Toto();console.log(instanceDeToto.constructor.name); // affiche "Toto" dans la console

Attention : l'interpréteur utilisera la propriété nativeFunction.name uniquement si la fonction ne possède pas une propriété en propre intituléename (cf section9.2.11 de la spécification ECMAScript2015). Cependant, ES2015 indique que les propriétés définies avec mot-cléstatic seront des propriétés propres de la fonction constructrice (cf. ECMAScript2015,14.5.14.21.b +12.2.6.9). Ainsi, il n'est plus possible d'obtenir le nom de la classe si celle-ci possède une méthode statique intituléename() :

js
class Toto {  constructor() {}  static name() {}}

Avecstatic name(),Toto.name ne contient plus le nom de la classe mais une référence à l'objetname(). La définition utilisée ci-avant se comporte de façon semblable à ce fragment de code ES5 :

js
function Toto() {}Object.defineProperty(Toto, "name", { writable: true });Toto.name = function () {};

Il est donc parfois erroné de penser queFunction.name pointe toujours vers le nom de la classe.

Noms de fonction sous la forme de symboles

Si un symbole (Symbol) est utilisé comme nom d'une fonction et que celui-ci dispose d'une description, c'est cette dernière qui sera utilisée comme nom de la méthode, entre crochets :

js
var sym1 = Symbol("Toto");var sym2 = Symbol();var o = {  [sym1]: function () {},  [sym2]: function () {},};o[sym1].name; // "[Toto]"o[sym2].name; // ""

Compresseurs et outils de minification JavaScript

Attention à l'utilisation deFunction.name lorsque le code source est transformé par certains outils. En effet, ceux-ci réduisent généralement la taille d'un programme en compressant les espaces et en modifiant parfois les noms de variables. Ainsi, un fragment de code comme :

js
function Toto() {}var toto = new Toto();if (Toto.constructor.name === "Toto") {  console.log("'toto' est une instance de 'Toto'");} else {  console.log("Oups !");}

pourrait être compressé en :

js
function a() {}var b = new a();if (b.constructor.name === "Toto") {  console.log("'toto' est une instance de 'Toto'");} else {  console.log("Oups !");}

Dans la version non-compressée, la condition du test est remplie et on affiche'toto' est une instance de 'Toto' dans la console. Mais dans la version compressée, la condition n'est pas vérifiée. Lorsqu'on utilisename, il faut s'assurer que les outils utilisés ne modifient pas le nom des fonctions.

Spécifications

Specification
ECMAScript® 2026 Language Specification
# sec-function-instances-name

Compatibilité des navigateurs

Help improve MDN

Learn how to contribute

Cette page a été modifiée le par lescontributeurs du MDN.


[8]ページ先頭

©2009-2025 Movatter.jp