TypeScript

TypeScript

Tutorial TypeScript: Polimorfismo

TypeScript polimorfismo: implementación y ejemplos. Aprende a implementar polimorfismo en TypeScript con ejemplos prácticos y detallados.

Aprende TypeScript GRATIS y certifícate

El polimorfismo es un concepto fundamental de la programación orientada a objetos que permite que un objeto pueda tomar muchas formas. Los objetos polimórficos pueden comportarse de diferentes maneras dependiendo del contexto en el que se utilizan. En otras palabras, un objeto puede responder a los mismos mensajes (métodos) de diferentes formas. TypeScript soporta polimorfismo y lo facilita con una sintaxis clara y eficiente.

Polimorfismo de subtipos

En TypeScript, el polimorfismo de subtipos es una forma de polimorfismo en la que una subclase puede ser tratada como su superclase (una clase hija puede ser tratada como su clase padre). Un objeto de la subclase puede ser utilizado en un lugar donde se espera un objeto de la superclase. Esto es posible debido a la relación de herencia entre la superclase y la subclase.

class Animal {
    comer() {
        console.log('El animal come');
    }
}

class Perro extends Animal {
    comer() {
        console.log('El perro come croquetas');
    }
}

class Gato extends Animal {
    comer() {
        console.log('El gato come pescado');
    }
}

function alimentarAnimal(animal: Animal) {
    animal.comer();
}

let miPerro = new Perro();
let miGato = new Gato();

alimentarAnimal(miPerro); // Imprime: "El perro come croquetas"
alimentarAnimal(miGato); // Imprime: "El gato come pescado"

En este código, Perro y Gato son subclases de Animal. El método alimentarAnimal espera un argumento de tipo Animal, pero se le puede pasar un objeto de tipo Perro o Gato porque ambos son subtipos de Animal. A esto se le llama polimorfismo.

Polimorfismo de clases abstractas

Las clases abstractas en TypeScript también permiten polimorfismo. Una clase abstracta es una clase que no se puede instanciar y que se utiliza como base para otras clases, y se declara mediante la palabra clave abstract. Las clases abstractas pueden tener métodos abstractos, que se definen pero no se implementan en la clase abstracta (no tienen cuerpo), y deben ser implementados por cualquier clase que extienda la clase abstracta.

// Clase abstracta
abstract class Animal {
    // Método abstracto, sin implementación
    abstract hacerSonido(): void;
}

class Perro extends Animal {
    hacerSonido() {
        console.log('Guau!');
    }
}

class Gato extends Animal {
    hacerSonido() {
        console.log('Miau!');
    }
}

let miPerro = new Perro();
let miGato = new Gato();
// No se podría hacer 'new Animal()' ya que Animal es clase abstracta

miPerro.hacerSonido(); // Imprime: "Guau!"
miGato.hacerSonido(); // Imprime: "Miau!"

Aquí, Animal es una clase abstracta con un método abstracto hacerSonido. Las clases Perro y Gato extienden Animal y proporcionan sus propias implementaciones del método hacerSonido.

Estos son sólo algunos ejemplos de cómo se puede utilizar el polimorfismo en TypeScript. La capacidad de tratar objetos de diferentes formas basándose en su tipo permite escribir código más genérico, flexible y reutilizable.

Aprende TypeScript GRATIS online

Ejercicios de esta lección Polimorfismo

Evalúa tus conocimientos de esta lección Polimorfismo con nuestros retos de programación de tipo Test, Puzzle, Código y Proyecto con VSCode, guiados por IA.

Funciones

TypeScript
Test

Funciones de primera clase

TypeScript
Puzzle

Tipos de utilidad

TypeScript
Puzzle

Clases

TypeScript
Test

OOP y CRUD en TypeScript

TypeScript
Proyecto

Tipos literales

TypeScript
Test

Namespaces

TypeScript
Test

Módulos

TypeScript
Test

Funciones TypeScript

TypeScript
Código

Encapsulación

TypeScript
Puzzle

Interfaces

TypeScript
Puzzle

Funciones puras

TypeScript
Puzzle

Variables y constantes

TypeScript
Código

Funciones flecha

TypeScript
Puzzle

Funciones puras

TypeScript
Test

Control de flujo

TypeScript
Código

Resolución de módulos

TypeScript
Test

Control de flujo

TypeScript
Puzzle

Polimorfismo

TypeScript
Test

Operadores

TypeScript
Test

Funciones flecha

TypeScript
Test

Herencia

TypeScript
Puzzle

Clases y objetos

TypeScript
Código

Clases

TypeScript
Puzzle

Operadores

TypeScript
Puzzle

Encapsulación

TypeScript
Test

Herencia

TypeScript
Test

Funciones

TypeScript
Puzzle

Tipos de unión e intersección

TypeScript
Test

Funciones de alto orden

TypeScript
Puzzle

Inmutabilidad

TypeScript
Puzzle

Interfaces

TypeScript
Test

Funciones de alto orden

TypeScript
Test

Tipos de unión e intersección

TypeScript
Puzzle

Tipos genéricos

TypeScript
Test

Control de flujo

TypeScript
Test

Polimorfismo

TypeScript
Puzzle

Interfaces

TypeScript
Código

Tipos literales

TypeScript
Puzzle

Tipos de utilidad

TypeScript
Test

Tipos genéricos

TypeScript
Puzzle

Inmutabilidad

TypeScript
Test

Herencia de clases

TypeScript
Código

Variables y constantes

TypeScript
Test

Variables y constantes

TypeScript
Puzzle

Funciones de primera clase

TypeScript
Test

Introducción a TypeScript

TypeScript
Test

Todas las lecciones de TypeScript

Accede a todas las lecciones de TypeScript y aprende con ejemplos prácticos de código y ejercicios de programación con IDE web sin instalar nada.

Accede GRATIS a TypeScript y certifícate

Certificados de superación de TypeScript

Supera todos los ejercicios de programación del curso de TypeScript y obtén certificados de superación para mejorar tu currículum y tu empleabilidad.

En esta lección

Objetivos de aprendizaje de esta lección

  1. Comprender el concepto de polimorfismo y su importancia en la programación orientada a objetos.
  2. Conocer el polimorfismo de subtipos en TypeScript, donde una subclase puede ser tratada como su superclase y ser utilizada en lugares donde se espera un objeto de la superclase.
  3. Aprender a utilizar clases abstractas en TypeScript y cómo declarar y utilizar métodos abstractos que deben ser implementados por las subclases.
  4. Entender cómo el polimorfismo permite escribir código más genérico, flexible y reutilizable, ya que los objetos pueden responder a los mismos mensajes de diferentes formas según su tipo.