Maison >interface Web >js tutoriel >Comment lister toutes les méthodes d'un objet en JavaScript ?
Liste de toutes les méthodes d'un objet
En JavaScript, vous pouvez énumérer les méthodes d'un objet à l'aide de la méthode Object.getOwnPropertyNames(). Cependant, vous pouvez également filtrer les propriétés non liées à la méthode, afin de vous assurer d'obtenir uniquement la fonctionnalité souhaitée.
Object.getOwnPropertyNames()
Object.getOwnPropertyNames( ) renvoie un tableau de toutes les propriétés (énumérables et non énumérables) qui appartiennent à un objet donné. Par exemple :
console.log(Object.getOwnPropertyNames(Math)); //-> ["E", "LN10", "LN2", "LOG2E", "LOG10E", "PI", ...etc ]
Méthodes de filtrage
Pour obtenir uniquement les méthodes, vous pouvez combiner Object.getOwnPropertyNames() avec la méthode filter() :
console.log(Object.getOwnPropertyNames(Math).filter(function (p) { return typeof Math[p] === 'function'; })); //-> ["random", "abs", "acos", "asin", "atan", "ceil", "cos", "exp", ...etc ]
Compatibilité du navigateur ES3
Dans les navigateurs ES3 (tels que IE 8 ou version antérieure), les propriétés d'objet intégrées ne sont pas énumérables, à l'exception de celles définies par le navigateur lui-même. (par exemple, fenêtre, document). Par conséquent, l'utilisation de l'approche ci-dessus ne capturera pas toutes les méthodes dans ces environnements.
Bogue IE avec { DontEnum }
Dans Internet Explorer, il existe un bug qui le provoque pour ignorer les propriétés avec l'attribut { DontEnum } dans un objet s'il existe une propriété du même nom dans la chaîne de prototypes qui a également { DontEnum }. Cela signifie qu'il est essentiel de nommer soigneusement les propriétés des objets lorsque vous travaillez avec IE pour éviter des problèmes potentiels.
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!