Knowledge base
es
es
  • Base de conocimiento
  • Bash scripting
    • Echemos un vistazo
  • Jenkins
    • Echemos un vistazo
  • Kafka
    • Echemos un vistazo
  • Kubernetes / Docker
    • Echemos un vistazo
  • Node.js
    • Echemos un vistazo
    • Node binary executable
      • Evaluando dinámicamente el código
      • Precarga de módulos
      • Límite de pila de datos (Stack trace)
    • Depuración y diagnóstico
    • Enfoque práctico de javascript
      • Tipos de datos
      • Funciones
      • Herencia de prototipos
        • Funcional
        • Funciones de constructor
        • Constructor (Class-Syntax)
      • Closure scope
    • Paquetes y dependencias
      • Inicializando paquetes
      • Dependencias
      • Package scripts
    • Sistema de módulos
    • Flujo de control asíncrono
      • Callbacks
      • Promises
      • Async/await
  • OAuth 2.0 / OpenID Connect
    • Echemos un vistazo
    • OpenID Connect
    • OAuth 2.0
      • Mejores prácticas de cómo manejar tokens
  • OpenShift
    • Echemos un vistazo
  • OWASP
    • Echemos un vistazo
  • SAML 2.0
    • Echemos un vistazo
  • SSL / TLS
    • Echemos un vistazo
  • Terraform
    • Echemos un vistazo
Powered by GitBook
On this page

Was this helpful?

  1. Node.js
  2. Enfoque práctico de javascript
  3. Herencia de prototipos

Funciones de constructor

  • Todas las funciones tienen prototipos.

  • El enfoque del constructor para crear una cadena de prototipos es definir propiedades en el objeto prototipo que después se llamará con new.

  • Cada función tiene un objeto prototipo preexistente.

Ejemplo:

Usaremos Pascal Case para las funciones que serán llamadas con new, ya que es una convención y es recomendable.

function Employee(name) {
  this.name = name;
}

Employee.prototype.salary = function () {
  console.log(`Su salario es de $.12,000.00`);
};

function Salesperson(name) {
  Employee.call(this, name);
}

function inherit(proto) {
  function ChainLink() {}
  ChainLink.prototype = proto;
  return new ChainLink();
}

Salesperson.prototype = inherit(Employee.prototype);

Salesperson.prototype.sell = function () {
  console.log(`Es vendido por ${this.name}`);
};

const smith = new Salesperson('Smith Peterson');

smith.sell(); // Es vendido por Smith Peterson
smith.salary(); // Su salario es de $.12,000.00
console.log(Object.getPrototypeOf(smith) === Salesperson.prototype); // true
console.log(Object.getPrototypeOf(Salesperson.prototype) === Employee.prototype); // true

Descripción de la cadena de prototipos:

  • El prototipo de smith es salesperson.prototype.

  • El prototipo de salesperson es employee.prototype.

  • El prototipo de employee es Object.prototype.

El uso del método call en una función permite que el objeto this de la función a la que se llama se establezca a través del primer argumento pasado a call.

Para el runtime que soporta ES6+, podemos obtener lo mismo con Object.create:

function Salesperson(name) {
  Employee.call(this, name);
}

Salesperson.prototype = Object.create(Employee.prototype);

Salesperson.prototype.sell = function () {
  console.log(`Es vendido por ${this.name}`);
};

Node.js tiene una función llamada util.inherits:

const util = require('util');

function Salesperson(name) {
  Employee.call(this, name);
}

Salesperson.prototype.sell = function () {
  console.log(`Es vendido por ${this.name}`);
};

util.inherits(Salesperson.prototype, Employee.prototype); // Object.setPrototypeOf(Salesperson.prototype, Employee.prototype)

PreviousFuncionalNextConstructor (Class-Syntax)

Last updated 3 years ago

Was this helpful?