Estados Computados en Programación Reactiva con Signals

Clase 21 de 71Curso de Angular: Creación de Aplicaciones Web

Resumen

¿Qué son los computed states y cómo se relacionan con los Signals?

En el mundo de la programación reactiva, especialmente con Angular, los computed states son esenciales para crear flujos de datos más eficientes y dinámicos. Estos estados se derivan de otros estados, utilizando los Signals como base. La idea es permitir que ciertas partes de la aplicación reaccionen de manera automática a los cambios de estado, facilitando la sincronización de datos y mejorando la experiencia del usuario.

¿Cómo implementar un filtro con estados computados?

Para ilustrar este concepto, podemos considerar un filtro para tareas en una aplicación. Imagine que queremos filtrar las tareas pendientes, completadas o mostrar todas. Este comportamiento puede lograrse utilizando un estado computado, que filtra las tareas basándose en el estado actual del filtro.

  1. Definir el estado del filtro: Comience creando un Signal para manejar el estado del filtro. Puede establecerse como un string con valores predeterminados como 'All', 'Pending' o 'Completed'.

    const filterState = signal('All');
    
  2. Cambio del estado del filtro: Cada vez que el usuario hace clic en una opción de filtro, se actualiza el estado del filtro.

    function changeFilter(newFilter: string) {
        filterState.set(newFilter);
    }
    
  3. Creación del computed state: Implementar un estado computado que dependa del estado del filtro y de la lista de tareas.

    const tasksByFilter = computed(() => {
        const currentFilter = filterState();
        const allTasks = tasks();
    
        switch (currentFilter) {
            case 'Pending':
                return allTasks.filter(task => !task.completed);
            case 'Completed':
                return allTasks.filter(task => task.completed);
            default:
                return allTasks;
        }
    });
    

¿Cómo manejar los errores comunes al usar computed states?

En ocasiones, al trabajar con strings para definir filtros, es fácil cometer errores tipográficos. Para evitar esto, TypeScript permite definir tipos restringidos que solo aceptan ciertos valores válidos.

  1. Definir los tipos permitidos: Limite los posibles valores de los strings para asegurar que el filtro solo acepte valores válidos.

    type FilterOptions = 'All' | 'Pending' | 'Completed';
    const filterState = signal<FilterOptions>('All');
    
  2. Verificación Tipográfica: Con los tipos restringidos, si se intenta pasar un valor no permitido, TypeScript generará un error, ayudando a prevenir bugs.

¿Cómo asegurar que la interfaz refleja los cambios de estado?

Un aspecto crítico es asegurarse de que la interfaz del usuario esté correctamente sincronizada con los cambios de estado. Esto incluye el conteo dinámico de tareas y la activación de botones específicos based on the current state.

  • Conteo dinámico: El contador de tareas debería reflejar el número de tareas según el filtro actual aplicado.

    const taskCount = computed(() => tasksByFilter().length);
    
  • Actualización de interfaz: Asegure que botones y elementos visuales se actualicen automáticamente en respuesta a cambios de estado.

Al seguir estas guías, lograrás una aplicación sincronizada y reactiva que mejora la experiencia del usuario, haciendo uso eficiente de los computed states junto con los Signals en Angular. ¡Sigue aprendiendo y explora más posibilidades con la programación reactiva!