Symbol.hasInstance

Le symbole « connu » Symbol.hasInstance est utilisé afin de déterminer si un objet constructeur reconnaît un objet comme une de ses instances. On peut donc adapter/personnaliser le comportement de l'opérateur instanceof grâce à ce symbole.

Attributs de Symbol.hasInstance
Écrivable Non
Énumérable Non
Configurable Non

Exemples

On peut implémenter un comportement différent pour instanceof de cette façon :

class MonArray {  
  static [Symbol.hasInstance](instance) {
    return Array.isArray(instance);
  }
}
console.log([] instanceof MonArray); // true

Spécifications

Spécification État Commentaires
ECMAScript 2015 (6th Edition, ECMA-262)
La définition de 'Symbol.hasInstance' dans cette spécification.
Standard Définition initiale.
ECMAScript (ECMA-262)
La définition de 'Symbol.hasInstance' dans cette spécification.
Standard évolutif  

Compatibilité des navigateurs

Update compatibility data on GitHub
OrdinateurMobileServeur
ChromeEdgeFirefoxInternet ExplorerOperaSafariWebview AndroidChrome pour AndroidFirefox pour AndroidOpera pour AndroidSafari sur iOSSamsung InternetNode.js
hasInstanceChrome Support complet 50Edge Support complet 15Firefox Support complet 50IE Aucun support NonOpera Support complet 37Safari Support complet 10WebView Android Support complet 50Chrome Android Support complet 50Firefox Android Support complet 50Opera Android Support complet 37Safari iOS Support complet 10Samsung Internet Android Support complet 5.0nodejs Support complet 6.5.0
Support complet 6.5.0
Support complet 6.0.0
Désactivée
Désactivée From version 6.0.0: this feature is behind the --harmony runtime flag.

Légende

Support complet  
Support complet
Aucun support  
Aucun support
Une action explicite de l'utilisateur est nécessaire pour activer cette fonctionnalité.
Une action explicite de l'utilisateur est nécessaire pour activer cette fonctionnalité.

Voir aussi