constructor

This translation is incomplete. Please help translate this article from English

El método constructor es un metodo especial para crear e inicializar un objeto creado a partir de una clase.

Sintaxis

constructor([argumentos]) { ... }

Descripción

Sólo puede haber un método especial con el nombre de "constructor" en una clase. Un error de sintaxis será lanzado, si la clase contiene más de una ocurrencia de un método constructor.

Un constructor puede utilizar la palabra clave super para llamar al constructor de una clase padre.

Si no especifica un método constructor, se utiliza un constructor predeterminado.

Ejemplos

Usando el método constructor

Este fragmento de código se toma de la classes sample (live demo).

class Square extends Polygon {
  constructor(length) {
    // Aquí, llama al constructor de la clase padre con sus longitudes
    // contemplando la anchura y la altura del Polígono
    super(length, length);
    // Nota: En las clases derivadas, super() se debe llamar primero
    // Se puede utilizar "this". Dejando esto causará un error de 
    //referencia.
    this.name = 'Square';
  }

  get area() {
    return this.height * this.width;
  }

  set area(value) {
    this.area = value;
  } 
}

Constructores por defecto

Si no especifica un método constructor, se utiliza un constructor predeterminado. Para las clases base, el constructor por defecto es:

constructor() {}

Para las clases derivadas, el constructor por defecto es:

constructor(...args) {
  super(...args);
}

Especificaciones

Specification Status Comment
ECMAScript 2015 (6th Edition, ECMA-262)
La definición de 'Constructor Method' en esta especificación.
Standard Initial definition.
ECMAScript (ECMA-262)
La definición de 'Constructor Method' en esta especificación.
Living Standard

Compatibilidad del navegador

Update compatibility data on GitHub
DesktopMobileServer
ChromeEdgeFirefoxInternet ExplorerOperaSafariAndroid webviewChrome para AndroidFirefox para AndroidOpera para AndroidSafari en iOSSamsung InternetNode.js
constructorChrome Soporte completo 49
Soporte completo 49
Sin soporte 42 — 49
Notas
Notas Strict mode is required.
Sin soporte 42 — 49
Deshabilitado
Deshabilitado From version 42 until version 49 (exclusive): this feature is behind the Experimental JavaScript preference (needs to be set to Enabled). To change preferences in Chrome, visit chrome://flags.
Edge Soporte completo 13Firefox Soporte completo 45IE Sin soporte NoOpera Soporte completo 36
Soporte completo 36
Sin soporte 29 — 36
Notas
Notas Strict mode is required.
Sin soporte 29 — 36
Deshabilitado
Deshabilitado From version 29 until version 36 (exclusive): this feature is behind the Experimental JavaScript preference (needs to be set to Enabled).
Safari Soporte completo 9WebView Android Soporte completo 49
Soporte completo 49
Sin soporte 42 — 49
Notas
Notas Strict mode is required.
Chrome Android Soporte completo 49
Soporte completo 49
Sin soporte 42 — 49
Notas
Notas Strict mode is required.
Sin soporte 42 — 49
Deshabilitado
Deshabilitado From version 42 until version 49 (exclusive): this feature is behind the Experimental JavaScript preference (needs to be set to Enabled). To change preferences in Chrome, visit chrome://flags.
Firefox Android Soporte completo 45Opera Android Soporte completo 36
Soporte completo 36
Sin soporte 29 — 36
Notas
Notas Strict mode is required.
Sin soporte 29 — 36
Deshabilitado
Deshabilitado From version 29 until version 36 (exclusive): this feature is behind the Experimental JavaScript preference (needs to be set to Enabled).
Safari iOS Soporte completo 9Samsung Internet Android Soporte completo 5.0
Soporte completo 5.0
Sin soporte 4.0 — 5.0
Notas
Notas Strict mode is required.
nodejs Soporte completo 6.0.0
Soporte completo 6.0.0
Soporte completo 4.0.0
Deshabilitado
Deshabilitado From version 4.0.0: this feature is behind the --use_strict runtime flag.
Soporte completo 5.0.0
Deshabilitado
Deshabilitado From version 5.0.0: this feature is behind the --harmony runtime flag.

Leyenda

Soporte completo  
Soporte completo
Sin soporte  
Sin soporte
Ver notas de implementación.
Ver notas de implementación.
El usuario debe de habilitar explícitamente esta característica.
El usuario debe de habilitar explícitamente esta característica.

Ver también