Maison > interface Web > js tutoriel > Comment distribuer des actions Redux avec des délais d'attente ?

Comment distribuer des actions Redux avec des délais d'attente ?

Linda Hamilton
Libérer: 2024-12-06 20:10:17
original
627 Les gens l'ont consulté

How to Dispatch Redux Actions with Timeouts?

Répartition des actions Redux avec délais d'attente

Problème

Supposons que vous disposiez d'une application Redux qui gère les notifications, affichant des messages tels que des erreurs ou des alertes informatives. Vous souhaitez ignorer automatiquement ces notifications après un certain temps, disons 5 secondes.

Solution : code asynchrone en ligne

L'approche la plus simple consiste à utiliser directement setTimeout :

store.dispatch({ type: 'SHOW_NOTIFICATION', text: 'You logged in.' });
setTimeout(() => {
  store.dispatch({ type: 'HIDE_NOTIFICATION' });
}, 5000);
Copier après la connexion

Solution : Extraire Async Action Creator

Pour éviter les duplications et les conditions de concurrence critique, envisagez d'extraire une action créateur :

function showNotificationWithTimeout(dispatch, text) {
  const id = nextNotificationId++;
  dispatch(showNotification(id, text));

  setTimeout(() => {
    dispatch(hideNotification(id));
  }, 5000);
}
Copier après la connexion

Ensuite, utilisez-le dans les composants :

showNotificationWithTimeout(this.props.dispatch, 'You just logged in.');
Copier après la connexion

Solution : utiliser le middleware Thunk

Le middleware Thunk offre plus de flexibilité. Il vous permet d'envoyer des fonctions qui renvoient des actions :

export function showNotificationWithTimeout(text) {
  return function (dispatch) {
    const id = nextNotificationId++;
    dispatch(showNotification(id, text));

    setTimeout(() => {
      dispatch(hideNotification(id));
    }, 5000);
  };
}
Copier après la connexion

Vous pouvez ensuite envoyer directement le créateur d'action thunk :

this.props.dispatch(showNotificationWithTimeout('You just logged in.'));
Copier après la connexion

Lecture de l'état dans Thunks

Thunks également vous permettent de lire l'état actuel du magasin :

export function showNotificationWithTimeout(text) {
  return function (dispatch, getState) {
    if (!getState().areNotificationsEnabled) {
      return;
    }

    // ...
  };
}
Copier après la connexion

Recommandations

Utilisez l'approche la plus simple qui répond à vos besoins. Thunks offre des fonctionnalités asynchrones avancées mais peut ne pas être nécessaire dans tous les cas.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal