Maison > interface Web > js tutoriel > Comment réinitialiser correctement l'état d'un magasin Redux lors de la déconnexion de l'utilisateur ?

Comment réinitialiser correctement l'état d'un magasin Redux lors de la déconnexion de l'utilisateur ?

DDD
Libérer: 2024-12-01 00:28:11
original
166 Les gens l'ont consulté

How to Properly Reset a Redux Store State Upon User Logout?

Réinitialisation de l'état du magasin Redux lors de la déconnexion de l'utilisateur

Dans Redux, le magasin maintient l'état de l'application. S'assurer que le magasin est réinitialisé à son état initial lorsqu'un utilisateur se déconnecte est essentiel pour éviter les problèmes de mise en cache et la contamination des données.

Pour y parvenir, une approche consiste à créer un réducteur de racine personnalisé. Il déléguera la gestion des actions aux réducteurs générés par combineReducers(). Cependant, lorsqu'il rencontre une action USER_LOGOUT, il renvoie l'état initial.

En supposant que vous ayez un rootReducer qui ressemble à ceci :

const rootReducer = combineReducers({
  // Your app's top-level reducers
});
Copier après la connexion

Vous pouvez le renommer en appReducer et définir un nouveau rootReducer qui délègue à appReducer :

const appReducer = combineReducers({
  // Your app's top-level reducers
});

const rootReducer = (state, action) => {
  return appReducer(state, action);
};
Copier après la connexion

Ensuite, apprenez au rootReducer à renvoie l'état initial lorsque l'action USER_LOGOUT est reçue. Les réducteurs sont connus pour renvoyer l'état initial lorsqu'ils sont appelés avec undefined comme premier argument, quel que soit le type d'action. Nous pouvons exploiter ce comportement :

const rootReducer = (state, action) => {
  if (action.type === 'USER_LOGOUT') {
    return appReducer(undefined, action);
  }

  return appReducer(state, action);
};
Copier après la connexion

Avec cette modification, tous les réducteurs seront réinitialisés lors de USER_LOGOUT, et ils pourront éventuellement renvoyer différents états en fonction de l'action.type.

Si votre application utilise redux-persist, vous devrez peut-être également effacer l'état stocké :

const rootReducer = (state, action) => {
  if (action.type === 'SIGNOUT_REQUEST') {
    // Remove the persisted state for all keys defined in your persistConfig(s)
    storage.removeItem('persist:root');
    // storage.removeItem('persist:otherKey');

    return appReducer(undefined, action);
  }

  return appReducer(state, action);
};
Copier après la connexion

Cette approche garantit que les fichiers en mémoire Le magasin Redux et l'état stocké sont réinitialisés lorsque l'utilisateur se déconnecte, conservant ainsi un état propre pour les sessions utilisateur ultérieures.

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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal