Facebook Pixel
Searching...
Español
EnglishEnglish
EspañolSpanish
简体中文Chinese
FrançaisFrench
DeutschGerman
日本語Japanese
PortuguêsPortuguese
ItalianoItalian
한국어Korean
РусскийRussian
NederlandsDutch
العربيةArabic
PolskiPolish
हिन्दीHindi
Tiếng ViệtVietnamese
SvenskaSwedish
ΕλληνικάGreek
TürkçeTurkish
ไทยThai
ČeštinaCzech
RomânăRomanian
MagyarHungarian
УкраїнськаUkrainian
Bahasa IndonesiaIndonesian
DanskDanish
SuomiFinnish
БългарскиBulgarian
עבריתHebrew
NorskNorwegian
HrvatskiCroatian
CatalàCatalan
SlovenčinaSlovak
LietuviųLithuanian
SlovenščinaSlovenian
СрпскиSerbian
EestiEstonian
LatviešuLatvian
فارسیPersian
മലയാളംMalayalam
தமிழ்Tamil
اردوUrdu
Learning JavaScript Design Patterns

Learning JavaScript Design Patterns

A JavaScript and React Developer's Guide
por Addy Osmani 2023 296 páginas
3.83
500+ calificaciones
Escuchar

Puntos clave

1. Los patrones de diseño en JavaScript optimizan la estructura del código y resuelven problemas comunes

Los patrones de diseño nos permiten construir sobre los hombros de desarrolladores que han definido soluciones a problemas y arquitecturas desafiantes durante varias décadas.

Soluciones reutilizables. Los patrones de diseño en JavaScript proporcionan soluciones probadas a desafíos comunes de programación. Ofrecen un vocabulario compartido para que los desarrolladores discutan e implementen estructuras de código eficientes. Al aprovechar estos patrones, los desarrolladores pueden:

  • Mejorar la organización y mantenibilidad del código
  • Aumentar la flexibilidad y escalabilidad del software
  • Facilitar la colaboración entre los miembros del equipo

Categorías de patrones. Los patrones de diseño se suelen categorizar en tres grupos principales:

  • Creacionales: Tratando con mecanismos de creación de objetos
  • Estructurales: Enfocándose en la composición y relaciones de objetos
  • Comportamentales: Abordando la comunicación entre objetos y la distribución de responsabilidades

Comprender y aplicar estos patrones puede mejorar significativamente la calidad y eficiencia de las aplicaciones JavaScript, llevando a bases de código más robustas y mantenibles.

2. Patrones creacionales: Constructor, Módulo, Singleton y Fábrica

El patrón Módulo encapsula el estado "privado" y la organización usando cierres.

Mecanismos de creación de objetos. Los patrones creacionales se centran en formas eficientes de crear objetos y gestionar los procesos de creación de objetos. Los patrones creacionales clave en JavaScript incluyen:

  • Patrón Constructor: Define la inicialización de objetos
  • Patrón Módulo: Encapsula el estado privado y las interfaces públicas
  • Patrón Singleton: Asegura que solo exista una instancia de una clase
  • Patrón Fábrica: Centraliza la lógica de creación de objetos

Modularidad y encapsulación. Estos patrones promueven:

  • Organización y reutilización del código
  • Privacidad de datos y acceso controlado
  • Instanciación flexible de objetos

Al emplear patrones creacionales, los desarrolladores pueden crear estructuras de código más mantenibles y escalables, especialmente en aplicaciones a gran escala donde la creación y gestión de objetos puede volverse compleja.

3. Patrones estructurales: Decorador, Fachada, Flyweight y Mixin

El patrón Decorador busca promover la reutilización del código.

Composición de objetos. Los patrones estructurales tratan con la composición de objetos, proporcionando formas de formar estructuras más grandes a partir de objetos individuales. Los patrones estructurales clave incluyen:

  • Decorador: Añade nueva funcionalidad a los objetos de manera dinámica
  • Fachada: Simplifica subsistemas complejos con una interfaz unificada
  • Flyweight: Comparte datos comunes entre múltiples objetos
  • Mixin: Añade propiedades y métodos a los objetos

Flexibilidad y eficiencia. Estos patrones ofrecen:

  • Mayor reutilización del código
  • Interfaces simplificadas para sistemas complejos
  • Uso optimizado de la memoria
  • Composición flexible de objetos

Los patrones estructurales permiten a los desarrolladores crear estructuras de objetos más flexibles y eficientes, mejorando el diseño y rendimiento general del sistema.

4. Patrones comportamentales: Observador, Mediador y Comando

El patrón Observador permite notificar a un objeto cuando otro objeto cambia sin requerir que el objeto conozca a sus dependientes.

Interacciones entre objetos. Los patrones comportamentales se centran en la comunicación entre objetos, definiendo cómo operan juntos. Los patrones comportamentales clave incluyen:

  • Observador: Define una dependencia de uno a muchos entre objetos
  • Mediador: Centraliza las comunicaciones complejas entre objetos
  • Comando: Encapsula una solicitud como un objeto

Mejora de la comunicación. Estos patrones proporcionan:

  • Acoplamiento suelto entre objetos
  • Control centralizado de las interacciones entre objetos
  • Flexibilidad en la ejecución y deshacer operaciones

Al implementar patrones comportamentales, los desarrolladores pueden crear sistemas más robustos y mantenibles, especialmente en aplicaciones complejas con numerosos componentes interactuantes.

5. Patrones arquitectónicos MVC, MVP y MVVM para la organización de aplicaciones

MVC se basa en el patrón Observador para parte de su comunicación central (algo que, sorprendentemente, no se cubre en muchos artículos sobre el patrón MVC).

Separación de preocupaciones. Estos patrones arquitectónicos proporcionan estructuras para organizar la lógica de la aplicación:

  • Modelo-Vista-Controlador (MVC): Separa los datos, la interfaz de usuario y la lógica de control
  • Modelo-Vista-Presentador (MVP): Similar a MVC, pero con una Vista más pasiva
  • Modelo-Vista-ViewModel (MVVM): Separa el desarrollo de la Vista de la lógica de negocio

Beneficios de los patrones arquitectónicos:

  • Mejora de la organización y mantenibilidad del código
  • Mayor capacidad de prueba de los componentes individuales
  • Facilitación de la colaboración entre desarrolladores
  • Mejor escalabilidad para aplicaciones grandes

Estos patrones ayudan a los desarrolladores a crear aplicaciones más organizadas, mantenibles y escalables al proporcionar estructuras claras para separar diferentes aspectos de la lógica de la aplicación.

6. Módulos modernos de JavaScript y patrones de programación asíncrona

El patrón async/await utiliza async/await como la forma principal de obtener datos de los Componentes del Servidor.

Organización modular del código. JavaScript moderno proporciona soporte de módulos incorporado, permitiendo a los desarrolladores crear bases de código más organizadas y mantenibles. Los conceptos clave incluyen:

  • Módulos ES6 con declaraciones de importación y exportación
  • Importaciones dinámicas para la división de código y optimización del rendimiento

Programación asíncrona. Los patrones para manejar operaciones asíncronas incluyen:

  • Promesas: Representan la eventual finalización de una operación asíncrona
  • Async/await: Azúcar sintáctico para trabajar con Promesas
  • Observables: Manejo de flujos de datos asíncronos

Estos patrones modernos permiten a los desarrolladores escribir código más limpio y eficiente para manejar operaciones asíncronas complejas y organizar aplicaciones a gran escala.

7. Patrones de diseño en React: Componentes de Orden Superior, Render Props y Hooks

Los Componentes de Orden Superior nos permiten mantener la lógica que queremos reutilizar en un solo lugar.

Composición de componentes. React ofrece varios patrones para crear componentes reutilizables y componibles:

  • Componentes de Orden Superior (HOCs): Mejoran los componentes con funcionalidad adicional
  • Render Props: Comparten código entre componentes usando una prop cuyo valor es una función
  • Hooks: Añaden características de estado y ciclo de vida a componentes funcionales

Beneficios de los patrones de React:

  • Mejora de la reutilización del código
  • Mejora de la composición de componentes
  • Simplificación de la gestión del estado
  • Reducción del código repetitivo

Estos patrones permiten a los desarrolladores crear aplicaciones React más flexibles, mantenibles y eficientes al promover la reutilización del código y la separación de preocupaciones.

8. Patrones de renderizado: En el lado del cliente, en el lado del servidor, estático e híbrido

El patrón PRPL se centra en cuatro consideraciones principales de rendimiento: Empujar recursos críticos de manera eficiente, Renderizar la ruta inicial lo antes posible, Pre-cargar activos en segundo plano y Cargar rutas o activos de manera perezosa.

Optimización del rendimiento. Varios patrones de renderizado buscan mejorar el rendimiento de la aplicación y la experiencia del usuario:

  • Renderizado en el lado del cliente (CSR): Renderiza contenido en el navegador
  • Renderizado en el lado del servidor (SSR): Genera HTML en el servidor
  • Renderizado estático: Pre-renderiza contenido en tiempo de compilación
  • Renderizado híbrido: Combina múltiples enfoques de renderizado

Consideraciones para los patrones de renderizado:

  • Tiempo de carga inicial y Tiempo para Interactivo (TTI)
  • Optimización para motores de búsqueda (SEO)
  • Carga del servidor y escalabilidad
  • Frecuencia de actualización del contenido

Elegir el patrón de renderizado adecuado depende de los requisitos específicos de la aplicación, equilibrando factores como el rendimiento, SEO y la complejidad del desarrollo.

9. Mejores prácticas de estructura de aplicaciones para proyectos escalables en React

Seguir un patrón definido para estructurar un proyecto te ayudaría a explicarlo a otros miembros del equipo y evitar que los proyectos se desorganicen y se vuelvan innecesariamente complicados.

Estructura organizada del proyecto. Implementar una estructura de proyecto clara y consistente es crucial para mantener aplicaciones React escalables. Las consideraciones clave incluyen:

  • Agrupar archivos por característica o módulo
  • Separar componentes de presentación y contenedores
  • Implementar una convención de nombres clara
  • Utilizar soluciones de gestión de estado adecuadas

Mejores prácticas:

  • Mantener los componentes pequeños y enfocados
  • Usar nombres de directorios significativos
  • Implementar carga diferida para un rendimiento optimizado
  • Mantener estándares de codificación consistentes

Una aplicación React bien estructurada mejora la mantenibilidad del código, facilita la colaboración entre los miembros del equipo y mejora la escalabilidad general del proyecto.

Última actualización:

Reseñas

3.83 de 5
Promedio de 500+ calificaciones de Goodreads y Amazon.

Aprendiendo Patrones de Diseño en Javascript recibe opiniones mixtas. Algunos elogian su cobertura exhaustiva de patrones de diseño y ejemplos prácticos, mientras que otros lo consideran desactualizado y demasiado centrado en bibliotecas específicas. Las reseñas positivas destacan su utilidad para desarrolladores intermedios y su relevancia duradera. Las críticas incluyen edición inconsistente, contenido anticuado y un énfasis excesivo en jQuery. Muchos lectores aprecian la explicación del libro sobre patrones comunes, pero sugieren que puede no ser la mejor opción para quienes buscan técnicas de JavaScript de vanguardia. En general, se considera una introducción sólida a los patrones de diseño, aunque con algunas limitaciones.

Sobre el autor

Addy Osmani es un Gerente de Ingeniería Senior en Google Chrome, liderando equipos dedicados a mejorar la eficiencia en el desarrollo web. Ha escrito varios libros y es un orador frecuente en conferencias internacionales. El trabajo de Osmani se centra en hacer que la web sea más rápida y fácil para que los desarrolladores la utilicen. Su experiencia en JavaScript y tecnologías web lo ha convertido en una figura respetada en la comunidad de desarrolladores. A través de sus escritos y presentaciones, Osmani comparte su conocimiento y perspectivas, contribuyendo al avance de las prácticas y técnicas de desarrollo web.

Other books by Addy Osmani

0:00
-0:00
1x
Dan
Andrew
Michelle
Lauren
Select Speed
1.0×
+
200 words per minute
Create a free account to unlock:
Requests: Request new book summaries
Bookmarks: Save your favorite books
History: Revisit books later
Ratings: Rate books & see your ratings
Unlock Unlimited Listening
🎧 Listen while you drive, walk, run errands, or do other activities
2.8x more books Listening Reading
Today: Get Instant Access
Listen to full summaries of 73,530 books. That's 12,000+ hours of audio!
Day 4: Trial Reminder
We'll send you a notification that your trial is ending soon.
Day 7: Your subscription begins
You'll be charged on Jan 25,
cancel anytime before.
Compare Features Free Pro
Read full text summaries
Summaries are free to read for everyone
Listen to summaries
12,000+ hours of audio
Unlimited Bookmarks
Free users are limited to 10
Unlimited History
Free users are limited to 10
What our users say
30,000+ readers
"...I can 10x the number of books I can read..."
"...exceptionally accurate, engaging, and beautifully presented..."
"...better than any amazon review when I'm making a book-buying decision..."
Save 62%
Yearly
$119.88 $44.99/year
$3.75/mo
Monthly
$9.99/mo
Try Free & Unlock
7 days free, then $44.99/year. Cancel anytime.
Settings
Appearance
Black Friday Sale 🎉
$20 off Lifetime Access
$79.99 $59.99
Upgrade Now →