{{JSRef}}
O symbol bem-conhecido Symbol.hasInstance
é usado para determinar se um objecto constructor reconhece um objecto como de sua instância. O comportamento do operador {{jsxref("Operators/instanceof", "instanceof")}} pode ser customizado por este symbol.
{{js_property_attributes(0,0,0)}}
Exemplos
Tu podes implementar o comportamento customizado do seu instanceof
deste jeito; por exemplo:
class MyArray { static [Symbol.hasInstance](instance) { return Array.isArray(instance); } } console.log([] instanceof MyArray); // true
Especificações
Specification | Status | Comment |
---|---|---|
{{SpecName('ES6', '#sec-symbol.hasinstance', 'Symbol.hasInstance')}} | {{Spec2('ES6')}} | Initial definition. |
{{SpecName('ESDraft', '#sec-symbol.hasinstance', 'Symbol.hasInstance')}} | {{Spec2('ESDraft')}} |
Compatibilidade com os navegadores
{{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}} |
Veja também
- {{jsxref("Operators/instanceof", "instanceof")}}