Cómo construir sistemas distribuidos en TypeScript

This ad is not shown to multipass and full ticket holders
JSNation US
JSNation US 2025
November 17 - 20, 2025
New York, US & Online
See JS stars in the US biggest planetarium
Learn More
In partnership with Focus Reactive
Upcoming event
JSNation US 2025
JSNation US 2025
November 17 - 20, 2025. New York, US & Online
Learn more
Bookmark
Rate this content

Aprende cómo ejecutar tu código TypeScript en el tiempo de ejecución de Temporal para obtener una confiabilidad extrema

This talk has been presented at TypeScript Congress 2022, check out the latest edition of this JavaScript Conference.

FAQ

Lauren es una ingeniera de tiempo de ejecución de lenguaje que trabaja en Temporal, particularmente en el SDK de TypeScript. Ella también es autora de un libro sobre GraphQL llamado la Guía de GraphQL.

En sistemas distribuidos como el manejo de transacciones con APIs externas (por ejemplo, Stripe), se abordan problemas como la idempotencia de las operaciones para evitar acciones repetidas y la consistencia entre la base de datos y la comprensión externa del mundo, como las discrepancias entre Stripe y la base de datos local.

En caso de fallos, se implementan estrategias como la cancelación de la reserva del inventario si el cobro falla, el reembolso y la cancelación de la reserva si el envío no procede, y reintentos de operaciones transitorias fallidas usando una función de reintentos con intentos máximos y tiempo de espera.

Un token de idempotencia es un identificador único utilizado para evitar que una operación se realice más de una vez. Es crucial en transacciones para asegurar que, aunque una solicitud se envíe múltiples veces, la operación solo se ejecute una vez, evitando duplicados y efectos no deseados.

Temporal proporciona un marco de ejecución de código duradero que gestiona y persiste el estado de los flujos de trabajo, asegurando que cada paso se ejecute correctamente y permitiendo retomar procesos exactamente en el mismo punto y estado en caso de fallos, lo que elimina la necesidad de manejar manualmente la persistencia y los reintentos.

Temporal utiliza un servidor y SDKs que gestionan la persistencia de los estados de los flujos de trabajo. Los trabajadores de Temporal reportan el progreso al servidor, que guarda cada estado del flujo de trabajo, permitiendo retomar el proceso en el mismo punto y estado incluso después de fallos.

Temporal permite escribir código a un nivel de abstracción más alto, donde la persistencia y los reintentos se manejan automáticamente. Esto libera a los desarrolladores de la responsabilidad de manejar directamente estos aspectos, lo que puede reducir errores y mejorar la eficiencia en el desarrollo de software.

Loren Sands-Ramshaw
Loren Sands-Ramshaw
10 min
29 Apr, 2022

Comments

Sign in or register to post your comment.
Video Summary and Transcription
Esta charla trata sobre la construcción de sistemas distribuidos en TypeScript, centrándose en una tienda de comercio electrónico e implementando un punto de creación de pedidos. Cubre el manejo de casos de reintento y errores, el guardado del estado del pedido, el manejo de fallas y pedidos duplicados, y la función y arquitectura de procesamiento de pedidos. La charla también presenta Temporal, un marco de ejecución de código duradero que simplifica el desarrollo de software tolerante a fallos.

1. Building Distributed Systems in TypeScript

Short description:

Así es como se construyen sistemas distribuidos en TypeScript. Trabajaremos en una tienda de comercio electrónico e implementaremos un punto de enlace para crear pedidos. Repasaremos todos los modos de fallo e intentaremos hacerlo más confiable. Reservamos el inventario, cobramos el pago y enviamos el paquete. Si alguna de estas etapas falla, la manejamos adecuadamente y consideramos reintentar.

Hola, amigos. Así es como se construyen sistemas distribuidos en TypeScript. Mi nombre es Lauren, y escribí un libro sobre GraphQL llamado la Guía de GraphQL, y actualmente trabajo como ingeniera de tiempo de ejecución de lenguaje en Temporal, trabajando en nuestro SDK de TypeScript.

Cuando trabajamos en un monolito, es posible que no tengamos muchas preocupaciones sobre sistemas distribuidos de las que preocuparnos. Si solo tenemos una capa de servidor de aplicaciones y una base de datos que realiza transacciones, es posible que solo estemos recibiendo una solicitud de un usuario, realizando una operación única y, si falla, le decimos a nuestro usuario que lo intente de nuevo. Si estamos hablando con API externas y son una parte esencial de la aplicación comercial como, por ejemplo, hablar con Stripe y decirle que cobre esto, y luego actualizar mi base de datos, entonces tengo algunos problemas más, como que es posible que no pueda comunicarme con Stripe. Así que necesito reintentarlo. Cuando reintentamos, debemos hacerlo de forma idempotente, para no cobrarle al usuario dos veces. Y hay casos en los que mi base de datos puede estar desincronizada con la comprensión de Stripe del mundo. Stripe devuelve éxito y no puedo comunicarme con la base de datos y esa operación falla o mi proceso se detiene antes de llegar a ese paso, entonces mis datos no son consistentes.

En esta charla, trabajaremos en una tienda de comercio electrónico e implementaremos un punto de enlace para crear pedidos. Y repasaremos todos los modos de fallo e intentaremos hacerlo más confiable, y no llegaremos a una confiabilidad total, pero veremos cuánto más simple podemos hacerlo si lo escribimos en temporal. Para comenzar, tenemos una función serverless alojada en Vercel, y obtenemos del cuerpo el ID del artículo, la cantidad y la dirección a la que se envía, y obtenemos el ID del usuario del frasco. Y luego tomamos tres pasos cada vez que tenemos un nuevo pedido. Reservamos el inventario con el servicio de inventario. Luego hablamos con el servicio de pagos para cobrar, y luego hablamos con el servicio de cumplimiento para enviar el paquete. Y respondemos con éxito.

Entonces, en un caso exitoso, esta lógica funciona bien, pero hay varias cosas que pueden salir mal. Si no podemos reservar, entonces no queremos continuar cobrando y enviando paquetes. Si logramos reservar y luego fallamos al cobrar, entonces no solo no queremos enviar el paquete, sino que también queremos cancelar la reserva del inventario para que otra persona pueda comprar esos artículos. Y por último, si la reserva y el cobro son exitosos y recibimos ese mismo paquete, entonces queremos reembolsar el cargo y cancelar la reserva. Ahora, cuando tenemos una falla, enviamos el estado 400 al cliente. Pero idealmente, estaríamos reintentando cada uno de estos pasos en caso de que la falla fuera transitoria, como un error de red o que el servicio estuviera temporalmente inactivo. Pero si lo intentamos nuevamente, tal vez funcione. Así que agreguemos reintentos a cada uno de estos pasos.

2. Manejo de Casos de Reintentos y Errores

Short description:

Tenemos una función de reintentos que maneja llamadas de servicio y las reintentamos con un retraso exponencial. Necesitamos un token de idempotencia para evitar llamadas duplicadas. También reintentamos las llamadas fallidas y capturamos los errores en el objeto de respuesta.

Tenemos una función de reintentos que toma parámetros, como intentos máximos y un tiempo de espera en intervalos. Y para cada uno de estos intentos, intenta llamar al servicio, compitiendo entre eso y el tiempo de espera. Entonces, si pasan 30 segundos y no hemos recibido respuesta del servicio, entonces reintentamos. Y cada vez que reintentamos, hacemos un retraso exponencial. Y aquí envolvemos cada una de estas llamadas de servicio en la función de reintentos.

Un problema que tenemos ahora al reintentar es que podríamos tener múltiples llamadas exitosas y necesitamos algún tipo de token de idempotencia para que el servicio sepa que no debe hacer la segunda vez. Y la mejor manera de hacer esto es obtenerlo del cliente. Así que lo agregaremos. Obtendremos un ID de solicitud del cuerpo y lo pasaremos a cada uno de los servicios.

También queremos reintentar estas llamadas fallidas, como si el reembolso falla, entonces ni reembolsaremos ni cancelaremos la reserva. Entonces el cliente terminará con el cargo y se tomará el inventario. Así que agreguemos eso. Envolveremos la cancelación de la reserva con la función de reintentos y también el reembolso. Además, cuando hablamos de lanzar, en realidad no estamos capturando el lanzamiento, solo estamos viendo si el objeto de respuesta tiene una propiedad de falla. Así que también capturaremos estos errores.

3. Guardando el Estado del Pedido y Manejando Errores

Short description:

Necesitamos guardar el estado del procesamiento del pedido en un almacenamiento duradero y en disco. Usamos el cliente de Mongo para conectarnos a la base de datos y actualizar el registro del pedido en cada paso. También necesitamos manejar errores de la base de datos y errores de lógica de compensación. Además, se requiere un grupo de trabajadores.

Entonces, obtenemos un objeto de reserva si nos comunicamos exitosamente con el servicio. Pero si no pudimos comunicarnos con el servicio, entonces eso lanzará una excepción y la capturamos, la guardamos aquí y luego la enviamos al usuario. Pero ¿qué sucede si este proceso se bloquea? En este punto, con todos estos reintentos, podríamos estar reintentando durante horas y ya no encajamos en la ventana de tiempo de una función sin servidor de Vercel.

Y así, a medida que tenemos estos procesos de larga duración, en algún momento, algunos de ellos fallarán, se bloquearán porque el servidor pierde energía o cualquier otra cosa. Y queremos poder retomar en el mismo estado en el que estábamos para poder continuar procesando el pedido. Y en este momento, la única conciencia de en qué paso estamos está en la memoria de este código.

Entonces, en cada paso, queremos guardar en algún almacenamiento duradero y en un disco en algún lugar en qué estado estamos , qué hemos hecho y qué nos queda por hacer. Así que hagámoslo. Tenemos el cliente de Mongo y los diferentes estados en los que puede estar un pedido. Nos conectamos a la base de datos, insertamos uno en el estado creado, obtenemos el ID y luego usamos eso para actualizar el mismo registro del pedido después de cada estado. Falló la reserva o se reservó, falló el cobro, etc. Hay varios otros problemas que no tenemos tiempo de solucionar. Queremos asegurarnos de que el cliente de la database esté reintentando y queremos manejar los errores de la database y queremos manejar estos errores de lógica de compensación. Y necesitamos tener un grupo de trabajadores.

4. Manejo de Fallas y Pedidos Duplicados

Short description:

Necesitamos un proceso para manejar fallas y continuar procesando registros no terminales en la base de datos. Temporal es un sistema que persiste y reintentar automáticamente nuestro código, eliminando la necesidad de manejo manual. En el sistema Temporal, iniciamos una función de procesamiento de pedidos usando el SDK de Temporal. Si la solicitud ya se ha iniciado, informamos al usuario que su pedido ya ha sido enviado.

En este momento, estamos dentro de un controlador HTTP, pero si esto falla, necesitamos que algún otro proceso en algún lugar se dé cuenta de que hay un registro en database en un estado no terminal. La última vez que se actualizó fue hace tanto tiempo que sé que nadie sigue trabajando en él, y el trabajador debe recogerlo y continuar. También probablemente queremos devolverle al usuario antes de que termine esta función porque todo este proceso de reintentos podría llevar minutos u horas.

No tengo tiempo para codificar esto. Probablemente tú tampoco tengas tiempo para codificar esto, y no deberíamos tener que hacerlo. Deberíamos estar trabajando a un nivel de abstracción donde todo lo que hacemos se persista automáticamente y se reintenten y no tengamos que preocuparnos por ello. Desafortunadamente, ese sistema existe y se llama Temporal. Veamos cómo se ve nuestra aplicación en el sistema Temporal. Aquí está la nueva función serverless. Todavía obtenemos los mismos datos. Solo hacemos un paso, y eso es client.start. Esto está utilizando el SDK de Temporal aquí arriba. Estamos iniciando una función de procesamiento de pedidos y le proporcionamos los argumentos del pedido y el ID de la solicitud como una especie de ID de la ejecución de la función y también un token de potencia, y luego respondemos que hemos enviado esto. Si esto ha sucedido, sabemos que se ha iniciado y guardado de forma duradera, y si obtenemos este error de ya iniciado, entonces sabemos que la solicitud era un duplicado. Así que decimos, hey, el pedido del usuario ya ha sido enviado.

5. Función de Procesamiento de Pedidos y Arquitectura

Short description:

Tenemos una función simple de procesamiento de pedidos con pasos como reserva, cobro, cancelación de reserva y envío del paquete. Estos pasos se implementan como actividades, que manejan posibles fallas. Cada función de actividad se reintenta y se agota el tiempo según la política de reintento. La función de procesamiento de pedidos se persiste, lo que permite continuar en el mismo estado si el proceso se interrumpe. El sistema también admite características adicionales como temporizadores y pausas. La arquitectura involucra un servidor temporal, entornos de ejecución de lenguaje y SDKs.

Ahora veamos esta función de procesamiento de pedidos. Tenemos cada paso, reserva, cobro. Si el cobro falla, entonces cancelamos la reserva y luego enviamos el paquete, y si eso falla, reembolsamos y luego cancelamos la reserva. Así que eso es muy simple. Esa es toda nuestra lógica y funciona.

Puede que estés pensando, bueno, pero estas funciones de reserva, cobro, etc., deben ser realmente complicadas. Veámoslas. Entonces, estas se llaman actividades, y usamos actividades para cualquier cosa que pueda fallar. Entonces, toda esta lógica no tiene riesgo de falla, pero todo lo que llama sí. Este es el servicio de reserva, cancelación de reserva. Puedes ver que son solo llamadas básicas al servicio. Cada una de estas funciones de actividad se reintenta y se agota el tiempo según mi política de reintento y cualquier opción que coloque aquí, hay muchas opciones diferentes. Todo eso es atendido por el sistema.

Además, cada paso de esta función de procesamiento de pedidos se persiste. Entonces, si el proceso se interrumpe después de esto, un nuevo trabajador continuará la ejecución en el mismo lugar exacto, en el mismo estado exacto y con cualquier variable local. Solo tenemos la variable 'order' aquí arriba, pero podríamos tener muchas otras que cambiamos durante la función. Todas tendrán los mismos valores. También puedes hacer otras cosas geniales como pausar durante 30 minutos. Estamos haciendo la compra de un solo clic de Amazon. Decimos reservar y luego establecemos un temporizador de 30 minutos, y luego cobramos. Y si nos cancelan durante esos 30 minutos, entonces no cobramos ni enviamos el paquete. También podemos pausar durante 30 días en un bucle si estamos intentando cobrar mensualmente a alguien en una suscripción.

Y la forma en que funciona esto es que tenemos un servidor temporal, que es de código abierto, y puedes alojarlo en cualquier lugar. Y eso hace la persistencia. Y tenemos entornos de ejecución de lenguaje o SDKs. Y el SDK se divide en un cliente y un trabajador. Y luego tienes un cliente que se puede usar en cualquier lugar. En este momento lo estamos usando en una función serverless. Y el cliente se comunica con el servidor temporal, y el trabajador se comunica con el servidor. Y el cliente dice, inicia este flujo de trabajo, que es esta función de procesamiento de pedidos.

6. Temporal: Un Marco de Ejecución de Código Duradero

Short description:

Temporal es un marco de ejecución de código duradero que te permite escribir código sin preocuparte por las fallas. Es un gran avance en el desarrollo de software, trabajando a un nivel de abstracción más alto. Obtén más información en temporal.io.ts o contáctame por correo electrónico a lauren.temporal.io o en Twitter a laurenDSR.

Y luego los trabajadores están constantemente extrayendo y recogiendo tareas del servidor. Como, ok, inicia esta función, inicia esta actividad, etc. Y el trabajador informa al servidor después de completar cada paso para que el servidor pueda persistirlo.

Entonces, cuando la gente me pregunta, ¿qué es Temporal? Digo que es un marco de ejecución de código duradero. Ejecutamos tu código en nuestros trabajadores y lo hacemos de manera duradera, de modo que si algo sale mal, lo retomamos en el mismo estado exacto. Y así puedes escribir tu código de una manera que sea ajena a las fallas. Eso es Temporal.

Creo que es un gran avance en el desarrollo de software, trabajando a un nivel de abstracción más alto en el que no tienes que preocuparte por la responsabilidad. Si quieres obtener más información, visita temporal.io.ts. Es la documentación del SDK de TypeScript. No dudes en enviarme un correo electrónico a lauren.temporal.io. Contáctame en Twitter, en la cuenta laurenDSR. Además, estamos contratando, así que si quieres trabajar conmigo, avísame.

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

Los tipos más útiles de React
React Day Berlin 2023React Day Berlin 2023
21 min
Los tipos más útiles de React
Top Content
Today's Talk focuses on React's best types and JSX. It covers the types of JSX and React components, including React.fc and React.reactnode. The discussion also explores JSX intrinsic elements and react.component props, highlighting their differences and use cases. The Talk concludes with insights on using React.componentType and passing components, as well as utilizing the react.element ref type for external libraries like React-Select.
TypeScript y React: Secretos de un matrimonio feliz
React Advanced 2022React Advanced 2022
21 min
TypeScript y React: Secretos de un matrimonio feliz
Top Content
React and TypeScript have a strong relationship, with TypeScript offering benefits like better type checking and contract enforcement. Failing early and failing hard is important in software development to catch errors and debug effectively. TypeScript provides early detection of errors and ensures data accuracy in components and hooks. It offers superior type safety but can become complex as the codebase grows. Using union types in props can resolve errors and address dependencies. Dynamic communication and type contracts can be achieved through generics. Understanding React's built-in types and hooks like useState and useRef is crucial for leveraging their functionality.
Haciendo Magia: Construyendo un Marco de Trabajo Primero-TypeScript
TypeScript Congress 2023TypeScript Congress 2023
31 min
Haciendo Magia: Construyendo un Marco de Trabajo Primero-TypeScript
Top Content
Daniel Rowe discusses building a TypeScript-first framework at TypeScript Congress and shares his involvement in various projects. Nuxt is a progressive framework built on Vue.js, aiming to reduce friction and distraction for developers. It leverages TypeScript for inference and aims to be the source of truth for projects. Nuxt provides type safety and extensibility through integration with TypeScript. Migrating to TypeScript offers long-term maintenance benefits and can uncover hidden bugs. Nuxt focuses on improving existing tools and finds inspiration in frameworks like TRPC.
Deja de Escribir Tus Rutas
Vue.js London 2023Vue.js London 2023
30 min
Deja de Escribir Tus Rutas
Top Content
Designing APIs is a challenge, and it's important to consider the language used and different versions of the API. API ergonomics focus on ease of use and trade-offs. Routing is a misunderstood aspect of API design, and file-based routing can simplify it. Unplugging View Router provides typed routes and eliminates the need to pass routes when creating the router. Data loading and handling can be improved with data loaders and predictable routes. Handling protected routes and index and ID files are also discussed.
Compilaciones de TypeScript más rápidas con --isolatedDeclarations
TypeScript Congress 2023TypeScript Congress 2023
24 min
Compilaciones de TypeScript más rápidas con --isolatedDeclarations
Top Content
This talk discusses the performance issues in TypeScript builds and introduces a new feature called isolated declarations. By running the compiler in parallel and using isolated modules, significant performance gains can be achieved. Isolated declarations improve build speed, compatibility with other tools, and require developers to write types in code. This feature has the potential to further increase performance and may be available in TypeScript soon.
Aplicaciones React (+Native) full-stack y seguras con tRPC.io
React Advanced 2021React Advanced 2021
6 min
Aplicaciones React (+Native) full-stack y seguras con tRPC.io
Top Content
Alex introduces tRPC, a toolkit for making end-to-end type-safe APIs easily, with auto-completion of API endpoints and inferred data from backend to frontend. tRPC works the same way in React Native and can be adopted incrementally. The example showcases backend communication with a database using queries and validators, with types inferred to the frontend and data retrieval done using Prisma ORM.

Workshops on related topic

React, TypeScript y TDD
React Advanced 2021React Advanced 2021
174 min
React, TypeScript y TDD
Top Content
Featured Workshop
Paul Everitt
Paul Everitt
ReactJS es extremadamente popular y, por lo tanto, ampliamente soportado. TypeScript está ganando popularidad y, por lo tanto, cada vez más soportado.

¿Los dos juntos? No tanto. Dado que ambos cambian rápidamente, es difícil encontrar materiales de aprendizaje precisos.

¿React+TypeScript, con los IDEs de JetBrains? Esa combinación de tres partes es el tema de esta serie. Mostraremos un poco sobre mucho. Es decir, los pasos clave para ser productivo, en el IDE, para proyectos de React utilizando TypeScript. En el camino, mostraremos el desarrollo guiado por pruebas y enfatizaremos consejos y trucos en el IDE.
Dominando conceptos avanzados en TypeScript
React Summit US 2023React Summit US 2023
132 min
Dominando conceptos avanzados en TypeScript
Top Content
Featured WorkshopFree
Jiri Lojda
Jiri Lojda
TypeScript no es solo tipos e interfaces. Únete a esta masterclass para dominar características más avanzadas de TypeScript que harán tu código a prueba de balas. Cubriremos tipos condicionales y notación de inferencia, cadenas de plantillas y cómo mapear sobre tipos de unión y propiedades de objetos/arrays. Cada tema se demostrará en una aplicación de muestra que se escribió con tipos básicos o sin tipos en absoluto y juntos mejoraremos el código para que te familiarices más con cada característica y puedas llevar este nuevo conocimiento directamente a tus proyectos.
Aprenderás:- - ¿Qué son los tipos condicionales y la notación de inferencia?- ¿Qué son las cadenas de plantillas?- Cómo mapear sobre tipos de unión y propiedades de objetos/arrays.
Consejos y Trucos Profundos de TypeScript
Node Congress 2024Node Congress 2024
83 min
Consejos y Trucos Profundos de TypeScript
Top Content
Featured Workshop
Josh Goldberg
Josh Goldberg
TypeScript tiene un sistema de tipos poderoso con todo tipo de características sofisticadas para representar estados de JavaScript salvajes y extravagantes. Pero la sintaxis para hacerlo no siempre es sencilla, y los mensajes de error no siempre son precisos al decirte qué está mal. Vamos a profundizar en cómo funcionan muchas de las características más poderosas de TypeScript, qué tipos de problemas del mundo real resuelven, y cómo dominar el sistema de tipos para que puedas escribir código TypeScript verdaderamente excelente.
Mejores Prácticas y Consejos Avanzados de TypeScript para Desarrolladores de React
React Advanced 2022React Advanced 2022
148 min
Mejores Prácticas y Consejos Avanzados de TypeScript para Desarrolladores de React
Top Content
Featured Workshop
Maurice de Beijer
Maurice de Beijer
¿Eres un desarrollador de React tratando de obtener los máximos beneficios de TypeScript? Entonces esta es la masterclass para ti.En esta masterclass interactiva, comenzaremos desde lo básico y examinaremos los pros y contras de las diferentes formas en que puedes declarar componentes de React usando TypeScript. Después de eso, pasaremos a conceptos más avanzados donde iremos más allá de la configuración estricta de TypeScript. Aprenderás cuándo usar tipos como any, unknown y never. Exploraremos el uso de predicados de tipo, guardias y comprobación exhaustiva. Aprenderás sobre los tipos mapeados incorporados, así como cómo crear tus propias utilidades de mapa de tipo nuevo. Y comenzaremos a programar en el sistema de tipos de TypeScript usando tipos condicionales e inferencia de tipos.
Practica Técnicas de TypeScript Construyendo una Aplicación con Componentes de Servidor React
TypeScript Congress 2023TypeScript Congress 2023
131 min
Practica Técnicas de TypeScript Construyendo una Aplicación con Componentes de Servidor React
Workshop
Maurice de Beijer
Maurice de Beijer
En esta masterclass práctica, Maurice te guiará personalmente a través de una serie de ejercicios diseñados para empoderarte con una profunda comprensión de los Componentes de Servidor React y el poder de TypeScript. Descubre cómo optimizar tus aplicaciones, mejorar el rendimiento y desbloquear nuevas posibilidades.
 
Durante la masterclass, realizarás:
- Maximizar la mantenibilidad y escalabilidad del código con prácticas avanzadas de TypeScript
- Desatar los beneficios de rendimiento de los Componentes de Servidor React, superando enfoques tradicionales
- Potenciar tu TypeScript con el poder de los Tipos Mapeados
- Hacer tus tipos TypeScript más seguros con Tipos Opacos
- Explorar el poder de los Tipos de Plantillas Literales al usar Tipos Mapeados
 
Maurice estará virtualmente a tu lado, ofreciendo una guía completa y respondiendo a tus preguntas mientras navegas por cada ejercicio. Al final de la masterclass, habrás dominado los Componentes de Servidor React, armado con un nuevo arsenal de conocimientos de TypeScript para potenciar tus aplicaciones React.
 
No pierdas esta oportunidad de elevar tu experiencia en React a nuevas alturas. Únete a nuestra masterclass y desbloquea el potencial de los Componentes de Servidor React con TypeScript. Tus aplicaciones te lo agradecerán.
Tipos avanzados de TypeScript para diversión y confiabilidad
TypeScript Congress 2022TypeScript Congress 2022
116 min
Tipos avanzados de TypeScript para diversión y confiabilidad
Workshop
Maurice de Beijer
Maurice de Beijer
Si estás buscando sacar el máximo provecho de TypeScript, este masterclass es para ti! En este masterclass interactivo, exploraremos el uso de tipos avanzados para mejorar la seguridad y previsibilidad de tu código TypeScript. Aprenderás cuándo usar tipos como unknown o never. Exploraremos el uso de predicados de tipo, guardias y verificación exhaustiva para hacer tu código TypeScript más confiable tanto en tiempo de compilación como en tiempo de ejecución. Aprenderás sobre los tipos mapeados incorporados, así como cómo crear tus propias utilidades de mapeo de tipos. Y comenzaremos a programar en el sistema de tipos de TypeScript utilizando tipos condicionales e inferencia de tipos.
¿Estás familiarizado con los conceptos básicos de TypeScript y quieres profundizar? Entonces únete a mí con tu computadora portátil en este masterclass avanzado e interactivo para aprender todos estos temas y más.
Puedes encontrar las diapositivas, con enlaces, aquí: http://theproblemsolver.nl/docs/ts-advanced-workshop.pdf
Y el repositorio que utilizaremos está aquí: https://github.com/mauricedb/ts-advanced