--- title: Symbol.hasInstance slug: Web/JavaScript/Reference/Global_Objects/Symbol/hasInstance tags: - Propriedade - Referencia translation_of: Web/JavaScript/Reference/Global_Objects/Symbol/hasInstance ---
O symbol bem-conhecido Symbol.hasInstance
é usado para determinar se um objeto construtor reconhece um objeto como de sua instância. O comportamento do operador {{jsxref("Operators/instanceof", "instanceof")}} pode ser customizado por este symbol.
Você pode implementar o comportamento customizado do seu instanceof
deste jeito; por exemplo:
class MyArray { static [Symbol.hasInstance](instance) { return this.prototype.isPrototypeOf(instance) || Array.isArray(instance); } } console.log([] instanceof MyArray); // true console.log(new MyArray instanceof MyArray); // true console.log(new Image instanceof MyArray); // false class MySubArray extends MyArray {} console.log(new MySubArray instanceof MySubArray); // true console.log(new MySubArray instanceof MyArray); // true console.log(new MyArray instanceof MySubArray); // false
Specification | Status | Comment |
---|---|---|
{{SpecName('ES6', '#sec-symbol.hasinstance', 'Symbol.hasInstance')}} | {{Spec2('ES6')}} | Initial definition. |
{{SpecName('ESDraft', '#sec-symbol.hasinstance', 'Symbol.hasInstance')}} | {{Spec2('ESDraft')}} |
{{CompatibilityTable}}
Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
Basic support | {{CompatChrome(51)}} | {{ CompatGeckoDesktop(50) }} | {{CompatNo}} | {{CompatUnknown}} | {{CompatUnknown}} |
Feature | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
Basic support | {{CompatUnknown}} | {{CompatUnknown}} | {{ CompatGeckoMobile(50) }} | {{CompatNo}} | {{CompatUnknown}} | {{CompatUnknown}} |