En esta segunda parte de introducción a TypeScript me gustaría seguir abordando algunos conceptos o características del lenguaje que me resultan interesante. En la primera parte, se introdujeron de manera muy elemental los elementos más básicos. Hicimos énfasis en los tipos básicos y la orientación del lenguaje al paradigma de programación basado en objetos. También se mencionó por qué usar TypeScript en detrimento de otras tecnologías. Dicho esto, sigamos analizando más características:
Módulos
Introducido con ECMAScript 2015. Permite exportar (export) e importar (import) clases, funciones o variables de un proyecto a otro, es decir, proporciona visibilidad. En el siguiente ejemplo se muestra algunas de sus posibilidades:
Decorators
Son funciones que pueden ser usadas para hacer anotaciones sobre clases, variables o métodos (inyección de dependencias, unit test, etcétera). También son usadas para generar metadatos, que pueden usarse por otras librerías con posterioridad. Básicamente, es una función que recibe un constructor. Veamos un sencillo ejemplo de ello, declarando el siguiente decorador:
Una vez definido, podemos emplearlo de la siguiente manera:
Mostrándose así el siguiente mensaje por consola:
Se trata de un ejemplo bastante básico y sencillo de su uso. En un futuro dedicaré un post aparte solo a este apartado.
Generators
Usa la sintaxis function* para ser creado. Devuelve un generator object. Siguen la interfaz iterator. Por tanto, provee los siguientes métodos: next, return y throw.
Devuelve junto con un resultado el estado de la iteración, si termina devuelve false y en caso contrario true.
Asyc/Await
Introducido en la versión 1.7, permite escribir código asíncrono. Con async declaramos la función asíncrona, que devuelve una promise, mientras que el operador await es usado para esperar dicha promise.
En el ejemplo anterior, cada input será pintado cada 400 milisegundos.
Generics
Permite diseñar clases y métodos que aplazan la especificación de uno o varios tipos hasta que el código declare y cree una instancia de dicha clase o método.
Union & Intersection types
Entramos en los tipos más avanzados. Los tipo Intersection pueden combinar más de un tipo y see usan mediante &. Por otro lado, la Union son entidades que pueden ser de un tipo u otro, dependiendo de su propósito. Dicha Union se representa mediante el símbolo |. Veámoslo con un ejemplo:
Como vemos, en la intersección al invocar un método u otro, ambos serán válidos ya que pet2 puede ser de tipo fish y bird. No obstante, no sucede lo mismo con pet1, ya que el método swim() no sabemos si estamos haciendo referencia a una entidad tipo Fish o Bird (si fuese ‘Bird’ provocaríamos un error al llamarlo).
Control Flow Analysis & Type Guards
Existen dos tipos de programadores: los que les gusta que los lenguajes sean fuertemente tipados y los que no. Para los que preferimos el primer caso, TypeScript proporciona herramientas para evitar problemas de mutabilidad. En primer lugar, el control flow analiza el flujo del programa para determinar de la manera más exacta el tipo de una variable que es declarado como Union Type. Un ejemplo:
En el primer caso, declaramos command como una variable de tipo String, por tanto, el compilador entenderá como siempre tendrá que tratarlo como tal, de modo que podremos invocar el método toUpperCase() para convertirlo en mayúscula. Por otro lado, si volvemos a declarar la misma variable como String[], ya dejará de ser tratado como String.
Además, esto nos permite limitar el tipo de un objeto dentro de un bloque condicional, por ejemplo:
En este caso, tenemos una función que puede recibir un tipo String o String[] y en la que vamos a determinar su comportamiento en función del tipo, algo muy útil en términos de seguridad.
Respecto a los Type Guards, es una expresión que realiza una verificación en tiempo de ejecución para garantizar el tipo en algún contexto y que se puede analizar en el Control Flow para ser lo más específico posible. Imaginemos que tenemos una aplicación para gestionar un videoclub en la que tenemos clientes de dos tipos: free o premium.
Aquí indicamos que si el usuario es premium, lo devuelva como tal y, además, actúe de una manera determinada (return user.customization.recap_freq;), sino que devuelva -1. TypeScript, lenguaje fuertemente tipado.
Esto es todo por ahora, pero hay mucho más. Poco a poco iremos abordando, de forma más concreta, cada una de sus características. Espero que os haya resultado útil.
En este post me gustaría hacer una breve introducción a TypeScript y analizar los motivos por los que está teniendo tanta popularidad en la comunidad. TypeScript es una tecnología creada y mantenida por Microsoft, de la mano de Anders Hejlsberg. En la actualidad, su última versión publicada es la 3.2, potencia y versatilidad desde sus inicios, TypeScript es ideal para usarlo en proyectos robustos y escalables, ya que es un superseteado de JavaScript en el que se añaden el tipado estático y los objetos basados en clases. Además de todo lo mencionado con anterioridad, es open source. A modo de resumen, empecemos citando algunas características destacadas del lenguaje:
Orientada a objetos: soporta todos los elementos de dicho paradigma de programación (clases, interfaces, herencia, polimorfismo, etcétera).
Lenguaje tipado: clasificación de las variables según los tipos de datos que usan.
Basado en estándares (ECMAScript).
Compilado: puedes detectar errores antes de ejecución (no interpreta). Convierte código a JavaScript.
Para programar en TypeScript lo más recomendable es usar Visual Studio Code, el editor de código basado en Electron y creado por Microsoft ofrece soporte para todas las versiones del lenguaje y, además, añade: Git integrado, debugging, IntelliSense y extensiones. Honestamente, para mí es uno de los mejores productos que ha hecho Microsoft en la última década.
¿Por qué usar TypeScript?
Ideal para proyectos escalables, orientado a un entorno empresarial. TypeScript está por grandes empresas y grandes proyectos, un claro de ejemplo de ello es Google, que usa para el desarrollo de Angular dicho lenguaje.
La documentación que existe sobre el proyecto es bastante y de calidad.
Para frontend y backend: si vienes de desarrollar en backend (como es mi caso), con TypeScript te sentirás como en casa. El lenguaje permite homogeneidad en este aspecto, aunque suela usarse para front, también puedes usarlo en el backend de tu aplicación.
La amplia y vibrante comunidad que hay detrás de TypeScript, son unos de los motivos fundamentales del éxito del lenguaje.
Interoperable con JavaScript.
Los comandos básicos que debes saber para comenzar con TypeScript son:
Instalar TypeScript, para ello tenemos que tener previamente instalado npm y Node:
Para compilar debemos usar el comando:
Entre las características principales del lenguaje, hemos destacado la introducción de clases, interfaces y funciones, elementos básicos en el paradigma de programación orientado a objetos. Dichos elementos en TypeScript, se presenta de la siguiente forma:
En la página oficial de TypeScript podemos mirar los tipos de datos básicos que pueden usarse, siendo los mismos que se pueden usar en JavaScript. Se destaca el tipo any, ideal para utilizarlo con librería de terceros en JavaScript que no están adaptadas a TypeScript, eso sí, no muy recomendado si quieres evitar problemas de mutabilidad. Otro a destacatar es el tipo tuple, que representa una colección de valores de varios tipos.
Por otro lado, si quieres comenzar a trastear con el lenguaje, en la página oficial existe una herramienta que te permitirá hacerlo. Hasta aquí el primer post de introducción al lenguaje, en el próximo se abordarán otras características del lenguaje como: decorators, generators, implementación async / await, etcétera.
Bienvenido a mi blog personal. Quien se dedica al mundo del software (de forma profesional o simplemente por hobby) sabe que es un campo que requiere que estés constantemente evolucionando, aprendiendo nuevas técnicas o tecnologías. Para ello, es fundamental que sientas pasión por lo que haces y, sobre todo, ser constante.
He creado este blog con el simple propósito de comprometerme con esta misión: aprender, no dejar nunca de aprender y compartir todo lo aprendido. Y que mejor manera de asimilar lo aprendido, que tratar de explicarlo. Por ello, el objetivo es publicar, al menos, un post al mes sobre alguna tecnología.
Sin más, espero que el contenido que aquí se genere te sea útil y que lo disfrutes.