Seleccionar página

La programación funcional está cogiendo fuerte tracción en los últimos años dentro de la comunidad de desarrollo. Tal vez ello se deba al surgimiento de nuevas arquitecturas que demandan cotas de escalabilidad, resistencia y flexibilidad en el marco de soluciones centradas en procesos de transformación. Pero más allá de una simple moda, como trataremos de mostrar en este taller, la programación funcional conduce a soluciones de código robustas, versátiles y expresivas que difícilmente son comparables con las propias de la orientación a objetos.

Además JavaScript, como la mayoría de los lenguajes de scripting es un lenguaje idiomático que invita a pensar en términos funcionales. De hecho muchas veces, cuando programamos en Javascript, desarrollamos soluciones funcionales casi sin darnos cuenta. Pero para trabajar correctamente en el marco de este paradigma debemos saber qué es exactamente la programación funcional, cuáles son sus ventajas y principios fundacionales, de qué mecanismos se sirve, qué técnicas de programación se utilizan, qué patrones de diseño funcional existen a nuestra disposición y qué estilos arquitectónicos emergen.

Este taller trata de dar una introducción a la programación funcional que comienza desde lo más básico y va pasando progresivamente hacia conceptos más avanzados. A continuación se resume una relación del programa de contenidos para que os hagáis una idea de lo que se va a abordar.

  • Diseño de Funciones I. Recursión
  • Diseño de Funciones II. Inmersion
  • Orden Superior I. Famila map & reduce
  • Orden Superior II. Evaluación Partial
  • Orden Superior III. Closures & Retentión Léxica
  • Composición I. compose & sequence
  • Composición II. Inversión de control
  • Composición III. Streams
  • Diseño sin Estado I. Fundamentos
  • Diseño sin Estado II. Mónadas
  • Conceptos Avanzados I. Optimización
  • Conceptos Avanzados II.Inmutabilidad

Todos estos temas se abordan en 12 ficheros .js dentro del repositorio en Github que se encuentran en la carpeta code/. Para falilitar la realización y autoevaluación, el material de este taller se ha dividido en dos carpetas. En code/problems puede encontrarse una descripción de cada ejercicio planteado junto con una plantilla de código que ayuda a escribir la solución y probarla. En la carpeta code/solutions se ofrece una propuesta de solución para cada ejercicio planteado. Se anima al lector a no consultar la solución hasta haber intentando cada ejercicio por si mismo.

Parte I. Recursividad e inmersión

Comenzamos el desarrollo de este taller presentando los constructos sintácticos propios de la programación funcional que ofrece JavaScript: funciones, invocación inmediata y el operador condicional como razonador por casos. Presentamos las claves esenciales del diseño de funciones recursivas y estudiamos las técnicas de abstracción basadas en inmersión por parámetros de recorrido y de acumulación.

Parte II. Familia map / reduce y evaluación parcial

Continuamos con algunos problemas de diseño recursivo basado en inmersión y presentamos la familia de funciones abstractas map / reduce. Más que usar las que nativamente implementa JavaScript desde ES5, nosotros primero las implementamos para conocer su anatomía interna y después las aplicamos en problemas. Finalmente presentamos y ejercitamos la evaluación parcial.

Taller avanzado

Diapositivas

Taller impartido por:

JavierVelezJavier Vélez Reyes
Ph. D. Computer Science
@javiervelezreye
Publicado por el autor en http://www.javiervelezreyes.com/

Novedades

HTTP2 para programadores. Enviar mensajes del servidor al cliente con Server Sent Event (sin WebSockets)

HTTP2 para programadores. Enviar mensajes del servidor al cliente con Server Sent Event (sin WebSockets)

En esta charla, organizada por MadridJS, Pablo Almunia nos muestra cómo la mayoría de nosotros cuando oímos hablar por primera vez de HTTP2 nos ilusionamos con las posibilidades que presumiblemente se abrían para el desarrollo de soluciones web avanzadas y cómo muchos nos sentimos defraudados con lo que realmente se podía implementar.

En esta charla podemos ver cómo funciona el HTTP2, que debemos tener en cuenta en el servidor para hace uso de este protocolo y, sobre todo, cómo podemos enviar información desde el servidor al cliente de forma efectiva y fácil. Veremos con detenimiento cómo por medio de los Server-Sent Events (SSE) podemos recibir en el cliente datos enviados desde el servidor sin utilizar websocket, simplificando enormemente la construcción de aplicaciones con comunicación bidireccional.

Observables en Javascript con Proxies

Observables en Javascript con Proxies

En esta charla, organizada por MadridJS, Pablo Almunia nos habla de la observación reactiva de objetos en Javascript por medio de Proxy. Se describe paso a paso cómo funcionan los Proxies y en que casos pueden ser nuestro mejor aliado. Veremos que no hay que tenerles miedo, son bastante sencillos de utilizar, y nos ofrecen una gran abanico de posibilidades.

Aplicaciones JAMStack, SEO friendly y escalables con NextJS

Aplicaciones JAMStack, SEO friendly y escalables con NextJS

En esta charla de Madrid JS, Rafael Ventura nos describe las funcionalidades clave de NextJS, nos muestra en vivo cómo desarrollar una completa aplicación JAMStack con Server Side Rendering (SSR) y Static Site Generation (SSG) y termina mostrando como publicar esta aplicación en Vercel.

Stencil JS: mejora el Time To Market de tu producto, por Rubén Aguilera

Stencil JS: mejora el Time To Market de tu producto, por Rubén Aguilera

En esta charla Rubén Aguilera nos cuenta los problemas que tienen muchas empresas a la hora de sacar productos accesibles, vistosos y usables en el Time To Market que requiere Negocio y cómo podemos minimizar este tiempo gracias al DevUI con StencilJS para adecuar una aplicación de Angular a las exigencias del mercado en tiempo record.