Maison >interface Web >js tutoriel >Boîte à outils Redux : création de fonctions Thunk

Boîte à outils Redux : création de fonctions Thunk

Susan Sarandon
Susan Sarandonoriginal
2024-12-23 13:39:05503parcourir

Redux Toolkit: Creating Thunk Functions

Qu'est-ce qu'un Thunk ?

En programmation, le mot thunk fait référence à la partie du code qui effectue un travail différé, comme les fonctions asynchrones en JavaScript.

En soi, un magasin Redux ne gère pas la logique asynchrone. Il sait seulement comment :

  1. Envoyer des actions de manière synchrone.
  2. Mettre à jour l'état via les réducteurs.
  3. Informez l'interface utilisateur des changements d'état.

Mais attendez, si c'est le cas, comment pouvons-nous appeler des API et mettre à jour l'état en fonction de leurs réponses, ce qui prend généralement du temps ? Comment pouvons-nous gérer cela ?

C'est là qu'interviennent les fonctions thunk.

Qu'est-ce qu'une fonction Thunk ?

Une fonction thunk est une fonction créée pour gérer la logique asynchrone, comme appeler une API. Il faut deux arguments dispatch et getState pour distribuer des actions et avoir accès à l'état actuel si nécessaire.

const getAllUsers = () => {
  return async (dispatch, getState) => {
    dispatch(fetingAllUsers());
    try {
      const users = await getUsers();
      dispatch(userUpdated(users));
    } catch (err) {
      dispatch(logError(err))
    }
  }
}

La fonction renvoyée est la fonction thunk et getAllUsers est appelé le créateur de l'action thunk dans cet exemple, et elle serait envoyée comme ceci :

dispatch(getAllUsers())

Un créateur d'action thunk peut être envoyé avec des arguments à utiliser dans la fonction thunk, si nécessaire.

Créer des Thunks avec createAsyncThunk

Redux Toolkit fournit l'API createAsyncThunk pour générer facilement des thunks :

import { createAsyncThunk } from '@reduxjs/toolkit';

export const fetchUserById = createAsyncThunk(
  'user/fetchUserById',
  async (userId) => {
    const user = await someHttpRequest(userId);
    return user;
  }
);

fetchUserById est la fonction thunk créée ici. createAsyncThunk prend deux arguments :

  • Le premier argument est un préfixe de chaîne utilisé pour les types d'action générés (par exemple user/fetchUserById/ending, user/fetchUserById/fulfilled ou user/fetchUserById/rejected).
  • Le deuxième argument est une fonction « créateur de charge utile ». Il devrait renvoyer une promesse avec les données requises ou une erreur.

Pourquoi utiliser createAsyncThunk ?

En plus de vous permettre de créer des fonctions thunk pour les appels d'API, createAsyncThunk distribue automatiquement des actions pour suivre l'état des requêtes d'API :

  • en attente : La demande est en cours.
  • remplie : La demande a réussi.
  • rejeté : la demande a échoué.

C'est vraiment utile. Par exemple, nous pouvons afficher un chargeur dans l'interface utilisateur lorsque l'état est en attente et informer l'utilisateur que quelque chose se passe.

Utiliser Thunks dans la tranche

Maintenant que nous avons créé le thunk fetchUserById, nous pouvons utiliser le champ extraReducers dans notre userSlice pour gérer les changements de statut d'état :

import { createSlice } from '@reduxjs/toolkit';

const initialState = {
  user: null,
  status: 'idle', // 'idle' | 'pending' | 'succeeded' | 'failed'
  error: null,
};

export const userSlice = createSlice({
  name: 'user',
  initialState,
  reducers: {
    usernameUpdated: (state, action) => {
      state.user.username = action.payload;
    },
    emailUpdated: (state, action) => {
      state.user.email = action.payload;
    },
    userDataCleared: (state) => {
      state.user = null;
      state.status = 'idle';
    },
  },
  extraReducers: (builder) => {
    builder
      .addCase(fetchUserById.pending, (state) => {
        state.status = 'pending';
      })
      .addCase(fetchUserById.fulfilled, (state, action) => {
        state.status = 'succeeded';
        state.user = action.payload;
      })
      .addCase(fetchUserById.rejected, (state, action) => {
        state.status = 'failed';
        state.error = action.error.message || 'Something went wrong.';
      });
  },
});

export const { usernameUpdated, emailUpdated, userDataCleared } = userSlice.actions;

// Selector for the status to use in the application's components
export const selectStatus = (state) => state.user.status;

conditions createAsyncThunk

Et si nous voulons vérifier certaines conditions avant d'appeler l'API ? Par exemple, si le statut est déjà en attente, nous ne voulons pas l’appeler deux fois. Dans ce cas, nous pouvons utiliser le troisième argument accepté par createAsyncThunk pour écrire des conditions.

const getAllUsers = () => {
  return async (dispatch, getState) => {
    dispatch(fetingAllUsers());
    try {
      const users = await getUsers();
      dispatch(userUpdated(users));
    } catch (err) {
      dispatch(logError(err))
    }
  }
}

Pour apprendre à utiliser Typescript avec les fonctions thunk, veuillez lire Type Checking Redux Thunks.

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!

Déclaration:
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
Article précédent:Quoi de neuf dans React 19Article suivant:Quoi de neuf dans React 19