Introducción a Angular y Fundamentos
Desarrollo de Aplicaciones Modernas con Angular
Creando tu primer proyecto en Angular
Creación de componentes y rutas en Angular para gestión de tareas
String Interpolation en Angular: Transmisión de Datos a Templates
Modificación de Propiedades HTML con Angular: Property Binding
Eventos en Angular: click, doble click y cambio de input
Eventos de Teclado en JavaScript: Uso de KeyDown y Change
Reactividad Granular con Signals en Angular
Reactividad en HTML: Implementación de Signals en JavaScript
Estructuras de control en Angular
Estructuras de Control y Renderizado Dinámico en Angular
Gestión Dinámica de Tareas en JavaScript: Creación y Eliminación
Estructuración de Tareas en JavaScript: Uso de Interfaces y Typing
Actualización de tareas con Angular y programación inmutable
Uso de ngIf y ngFor para control de flujos en Angular
Pluralización y ngSwitch en Angular para manejo de condiciones múltiples
Manejo Avanzado de Formularios Reactivos en Angular
Validaciones de Inputs en Formularios Reactivos con Angular
Alistando tu aplicación para producción
Validación de formularios y estilos dinámicos en Angular
Activación dinámica de clases en Angular con validaciones
Edición de Tareas Dinámicas en Aplicaciones Web
Estados Computados en Programación Reactiva con Signals
Persistencia de Tareas con LocalStorage en Angular
Compilación y Optimización de Aplicaciones Angular para Producción
Lanzamiento de Aplicaciones con Fiverr Hosting y Angular
Nuevas Sintaxis Declarativas en Angular Inspiradas en Svelte
Sintaxis y rendimiento de for y switch en JavaScript moderno
Migración Automática a Nueva Sintaxis de Angular
Componentes Reutilizables y Comunicación
Creación de Tienda en Línea con Angular y Tailwind CSS
Creación y Organización de Componentes en Angular
Componentes Reutilizables en Angular: Creación y Maquetado de Productos
Uso de Angular DevTools para Debugging en Angular
Inputs en Angular: Comunicación de Datos entre Componentes
Outputs en Angular: Comunicación del Hijo al Padre
Maquetación de Galería de Productos con Tailwind CSS
Ciclo de vida de los componentes
Ciclo de Vida de Componentes en Angular
Creación y Uso de Componentes en Angular: Ciclo de Vida y Comunicación
Ciclo de Vida de Componentes en Angular: Eventos Clave
Detección de Cambios en Inputs con ngOnChange en Angular
Prevención de fugas de memoria con ngOnDestroy en Angular
Creación de un Reproductor de Audio con WaveSurfer.js en Angular
Mejoras de la página About en e-commerce: audio y contador dinámico
Mejorando la interfaz del producto
Componentización y Manejo de Datos en Angular
Creación de Headers en Páginas Web con Angular
Implementación de Interfaz Gráfica para Carrito de Compras Interactivo
Implementación de Reactividad en Carrito de Compras con Angular
Gestión de Carrito de Compras en Angular con ngOnChanges
Gestión de Estado en Angular: Solución al InputDrilling
Gestión de Estado Global en Angular con Servicios y Señales
Inyección de Dependencias en Angular: Conceptos y Prácticas
Integración y Datos
Conexión de Angular a REST API usando Fake Store API de Platzi
Creación de Alias para Imports Cortos en Proyectos JavaScript
Transformación de Datos con Pipes en Angular
Creación y uso de pipes personalizados en Angular
Manipulación de Fechas en Angular con Date Functions
Manipulación del DOM con Directivas en Angular
Deployment de Aplicaciones Angular en Vercel
Enrutamiento y Navegación
Creación de Página 404 en Angular: Manejo de Rutas No Encontradas
Implementación de Router Link en Angular para SPA eficiente
Implementación de Layouts Compartidos en Angular para Vistas Anidadas
Uso de RouterLinkActive en Angular para Navegación Activa
Routing en Angular: Creación de Páginas de Detalle de Producto
Consulta dinámica de detalles de producto con Angular y REST API
Galería de Productos Dinámica con Angular y TypeScript
Mejoras en Detalle de Producto: Precio, Carrito e Imagen Activa
Perfeccionando tu e-commerce
Filtrado de Productos por Categoría en E-commerce
Filtros de Productos con Query Params en Angular
Optimización de Aplicaciones con Lazy Loading y Code Splitting
Optimización de JavaScript en Angular con Lazy Loading
Optimización de Carga de Chunks con Preloading en Angular
Migración de Angular a Nueva Sintaxis con ng generate
Despliegue de Aplicaciones con Verzal en Entornos Productivos
No tienes acceso a esta clase
¡Continúa aprendiendo! Únete y comienza a potenciar tu carrera
Para ajustar la reactividad en el counter y asegurar que el botón correspondiente esté activo según el filtro seleccionado, necesitamos realizar algunos cambios en nuestro código. Inicialmente, el counter debe reflejar el estado de las tareas mostradas al usuario. En lugar de leer el array de tareas, ahora leemos del estado derivado, tagsByFilter
, que contiene el estado de las tareas bajo el filtro activo.
Además, resulta esencial que el botón apropiado se active de acuerdo con el filtro seleccionado. Utilizaremos clases dinámicas con el property binding para activar la clase selected
cuando el filtro coincida con el valor esperado. Esto se puede lograr suscribiéndose al filtro y haciendo una validación de igualdad. Gracias a la tipificación, el filtro solo puede estar en uno de tres estados: all
, pending
o completed
, lo cual nos brinda una validación automática de los estados permitidos, evitando errores por typos.
La persistencia de los datos es crítica en cualquier aplicación para evitar la pérdida de información tras un refresco de página. Vamos a implementar persistencia en nuestra app de tareas usando localStorage
, un método de almacenamiento pequeño del navegador:
Efectos para guardar cambios: Utilizamos effects
, una característica de Angular, para guardar automáticamente cada cambio de estado en localStorage
. Se debe instanciar un effect
dentro de un constructor que monitoriza los cambios en las tareas y las guarda en localStorage
.
Serialización: Convertimos el array de tareas en una cadena JSON usando JSON.stringify()
antes de almacenarlo para garantizar que localStorage
pueda manejarlo correctamente.
Almacenamiento y carga de datos: Al iniciar la aplicación, verificamos si ya existen datos en localStorage
. De ser así, estos se cargan como estado inicial, deserializándolos nuevamente en un objeto JavaScript utilizando JSON.parse()
.
ngOnInit
?Durante la inicialización del componente, utilizamos ngOnInit
para cargar las tareas desde localStorage
:
Verificación de datos: Antes de inicializar el estado de las tareas, comprobamos si localStorage
tiene datos almacenados. Si existen, los convertimos de texto a objetos y los utilizamos como estado inicial.
Configuración del environment: Eliminamos los estados predeterminados del código y dejamos un array vacío para que se pueble con los datos de localStorage
. Esto ayuda a mantener la flexibilidad de la aplicación.
Un aspecto importante al usar effects
es prevenir el borrado accidental de datos debido a que effect
se ejecuta al inicio del estado:
Configuración posinicialización: Para evitar la limpieza del storage cada vez que se inicia la app, configuramos nuestros effects
para que se activen después de que el almacenamiento ya se haya leído e inicializado durante el ciclo de vida del componente.
Uso de injectores: Al mover el effect
fuera del constructor, empleamos injectors
para garantizar que el effect
tenga el contexto necesario para funcionar correctamente.
Con estas estrategias, garantizamos que nuestros datos permanezcan persistentes a través de diferentes sesiones del navegador y que se reactive el estado correcto cuando sea necesario. Así, nuestra aplicación de gestión de tareas no solo es reactiva y sensible al contexto del usuario, sino que también proporciona una experiencia de usuario sólida y consistente. ¡Sigue explorando Angular y sus amplias capacidades para hacer aplicaciones web increíbles!
Aportes 16
Preguntas 2
Fuente: ChatGPT.
En Angular 17, usar { injector: this.injector } en la función effect asegura que el efecto tenga el contexto correcto del inyector de dependencias del componente. Esto es necesario para resolver correctamente las dependencias y servicios usados en el efecto, y para gestionar de manera adecuada el ámbito y ciclo de vida del efecto en relación con el componente. Es una práctica recomendada para mantener la integridad y coherencia del manejo de estados y dependencias en el componente.
Opté por colocar la lógica de ‘effect’ en el constructor en lugar de ngOnInit porque ‘effect’ es una función sincrónica. En Angular, el constructor es un buen lugar para inicializar propiedades y ejecutar lógica que no depende de servicios externos o datos asíncronos. Además, reservo ngOnInit para actividades que involucran operaciones asíncronas o dependencias externas.
constructor() {
const storage = window.localStorage.getItem('tasks');
if (storage) {
const tasks = JSON.parse(storage);
this.tasks.set(tasks);
}
this.updateLocalStorage();
}
Créditos a ChatGPT 🤖
✅
¿Quieres ver más aportes, preguntas y respuestas de la comunidad?