Symbol.hasInstance
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since April 2017.
TheSymbol.hasInstance static data property represents thewell-known symbolSymbol.hasInstance. Theinstanceof operator looks up this symbol on its right-hand operand for the method used to determine if the constructor object recognizes an object as its instance.
In this article
Try it
class Array1 { static [Symbol.hasInstance](instance) { return Array.isArray(instance); }}console.log([] instanceof Array1);// Expected output: trueValue
The well-known symbolSymbol.hasInstance.
Property attributes ofSymbol.hasInstance | |
|---|---|
| Writable | no |
| Enumerable | no |
| Configurable | no |
Description
Theinstanceof operator uses the following algorithm to calculate the return value ofobject instanceof constructor:
- If
constructorhas a[Symbol.hasInstance]()method, then call it withobjectas the first argument and return the result,coerced to a boolean. Throw aTypeErrorifconstructoris not an object, or ifconstructor[Symbol.hasInstance]is not one ofnull,undefined, or a function. - Otherwise, if
constructordoesn't have a[Symbol.hasInstance]()method (constructor[Symbol.hasInstance]isnullorundefined), then determine the result using the same algorithm asFunction.prototype[Symbol.hasInstance](). Throw aTypeErrorifconstructoris not a function.
Because all functions inherit fromFunction.prototype by default, most of the time, theFunction.prototype[Symbol.hasInstance]() method specifies the behavior ofinstanceof when the right-hand side is a function.
Examples
>Custom instanceof behavior
You could implement your custominstanceof behavior like this, for example:
class MyArray { static [Symbol.hasInstance](instance) { return Array.isArray(instance); }}console.log([] instanceof MyArray); // truefunction MyArray() {}Object.defineProperty(MyArray, Symbol.hasInstance, { value(instance) { return Array.isArray(instance); },});console.log([] instanceof MyArray); // trueChecking the instance of an object
Just in the same manner at which you can check if an object is an instance of a class using theinstanceof keyword, we can also useSymbol.hasInstance for such checks.
class Animal { constructor() {}}const cat = new Animal();console.log(Animal[Symbol.hasInstance](cat)); // trueSpecifications
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-symbol.hasinstance> |