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 September 2015.

El símbolo conocido como Symbol.hasInstance se utiliza para determinar si un objeto constructor reconoce un objeto como su instancia. El comportamiento del operador instanceof puede personalizarse mediante este símbolo.

Pruébalo

class Array1 {
  static [Symbol.hasInstance](instance) {
    return Array.isArray(instance);
  }
}

console.log([] instanceof Array1);
// Expected output: true
Atributos de la propiedad Symbol.hasInstance
SobrescribirNo
NumerableNo
ConfigurableNo

Ejemplos

Comportamiento de instanceof personalizado

Podrías personalizar el comportamiento de instanceof de la siguiente manera, por ejemplo:

js
class MyArray {
  static [Symbol.hasInstance](instance) {
    return Array.isArray(instance);
  }
}
console.log([] instanceof MyArray); // true
js
function MyArray() {}
Object.defineProperty(MyArray, Symbol.hasInstance, {
  value: function (instance) {
    return Array.isArray(instance);
  },
});
console.log([] instanceof MyArray); // true

Comprobación de la instancia de un objeto

De la misma manera que se puede comprobar si un objeto es una instancia de una clase utilizando la palabra clave instanceof, también podemos utilizar Symbol.hasInstance para dichas comprobaciones.

js
class Animal {
  constructor() {}
}

const cat = new Animal();

console.log(Animal[Symbol.hasInstance](cat)); // true

Especificaciones

Specification
ECMAScript® 2025 Language Specification
# sec-symbol.hasinstance

Compatibilidad con navegadores

Report problems with this compatibility data on GitHub
desktopmobileserver
Chrome
Edge
Firefox
Opera
Safari
Chrome Android
Firefox for Android
Opera Android
Safari on iOS
Samsung Internet
WebView Android
WebView on iOS
Deno
Node.js
hasInstance

Legend

Tip: you can click/tap on a cell for more information.

Full support
Full support

Véase también