Dans cette partie, nous aborderons la requête RTK
1. Qu'est-ce que la requête RTK ?
Bien que Redux Toolkit fournisse des outils puissants pour gérer l'état et la logique asynchrone, il nécessite toujours un code passe-partout important pour gérer la récupération et la mise en cache des données. RTK Query, introduit dans Redux Toolkit v1.6, vise à résoudre ce problème en fournissant un ensemble d'outils puissants pour une récupération et une mise en cache efficaces des données avec une configuration minimale.
Principales fonctionnalités de la requête RTK :
Pour démarrer avec RTK Query, nous devons définir un service API qui spécifie comment récupérer les données et quels points de terminaison sont disponibles. Créons un exemple en utilisant une simple API de publications.
Créez un nouveau fichier nommé postsApi.js dans le répertoire feature/posts. Ce fichier définira les points de terminaison de l'API pour la récupération et la mutation des publications.
// src/features/posts/postsApi.js import { createApi, fetchBaseQuery } from '@reduxjs/toolkit/query/react'; // Define an API service using RTK Query export const postsApi = createApi({ reducerPath: 'postsApi', baseQuery: fetchBaseQuery({ baseUrl: 'https://jsonplaceholder.typicode.com/' }), endpoints: (builder) => ({ fetchPosts: builder.query({ query: () => 'posts', }), addPost: builder.mutation({ query: (newPost) => ({ url: 'posts', method: 'POST', body: newPost, }), }), }), }); // Export hooks for usage in functional components export const { useFetchPostsQuery, useAddPostMutation } = postsApi;
Explication :
Ajoutez le réducteur postsApi au magasin et configurez le middleware pour activer la mise en cache et l'invalidation.
Mettre à jour store.js pour intégrer postsApi :
// src/app/store.js import { configureStore } from '@reduxjs/toolkit'; import { postsApi } from '../features/posts/postsApi'; const store = configureStore({ reducer: { // Add the generated reducer as a specific top-level slice [postsApi.reducerPath]: postsApi.reducer, }, // Adding the api middleware enables caching, invalidation, polling, and other features of RTK Query middleware: (getDefaultMiddleware) => getDefaultMiddleware().concat(postsApi.middleware), }); export default store;
RTK Query génère des hooks personnalisés basés sur les points de terminaison définis dans le service API. Ces hooks sont utilisés pour effectuer la récupération de données, les mutations et gérer automatiquement la mise en cache.
Créez un composant PostsList.js pour récupérer et afficher la liste des publications.
// src/features/posts/PostsList.js import React from 'react'; import { useFetchPostsQuery } from './postsApi'; const PostsList = () => { const { data: posts, error, isLoading } = useFetchPostsQuery(); if (isLoading) return <p>Loading...</p>; if (error) return <p>An error occurred: {error.message}</p>; return ( <section> <h2>Posts</h2> <ul> {posts.map((post) => ( <li key={post.id}>{post.title}</li> ))} </ul> </section> ); }; export default PostsList;
Explication :
Créez un composant AddPostForm.js pour ajouter de nouvelles publications à l'aide de la mutation addPost.
// src/features/posts/AddPostForm.js import React, { useState } from 'react'; import { useAddPostMutation } from './postsApi'; const AddPostForm = () => { const [addPost, { isLoading }] = useAddPostMutation(); const [title, setTitle] = useState(''); const [content, setContent] = useState(''); const handleSubmit = async (e) => { e.preventDefault(); if (title && content) { await addPost({ title, body: content }).unwrap(); setTitle(''); setContent(''); } }; return ( <section> <h2>Add a New Post</h2> <form onSubmit={handleSubmit}> <input type="text" value={title} onChange={(e) => setTitle(e.target.value)} placeholder="Post Title" /> <textarea value={content} onChange={(e) => setContent(e.target.value)} placeholder="Post Content" /> <button type="submit" disabled={isLoading}> {isLoading ? 'Adding...' : 'Add Post'} </button> </form> </section> ); }; export default AddPostForm;
Explication :
RTK Query gère automatiquement la mise en cache, les états d'erreur et invalide le cache lorsque des mutations se produisent. Vous pouvez personnaliser davantage le comportement avec des balises et d'autres configurations.
Modifiez postsApi pour utiliser des balises pour l'invalidation du cache :
// src/features/posts/postsApi.js import { createApi, fetchBaseQuery } from '@reduxjs/toolkit/query/react'; export const postsApi = createApi({ reducerPath: 'postsApi', baseQuery: fetchBaseQuery({ baseUrl: 'https://jsonplaceholder.typicode.com/' }), tagTypes: ['Post'], endpoints: (builder) => ({ fetchPosts: builder.query({ query: () => 'posts', providesTags: (result) => result ? result.map(({ id }) => ({ type: 'Post', id })) : ['Post'], }), addPost: builder.mutation({ query: (newPost) => ({ url: 'posts', method: 'POST', body: newPost, }), invalidatesTags: ['Post'], }), }), }); export const { useFetchPostsQuery, useAddPostMutation } = postsApi;
Explication :
Dans cette partie, nous avons exploré comment utiliser RTK Query pour gérer la récupération et la mise en cache des données dans les applications Redux. Nous avons couvert la configuration d'un service API, la définition des points de terminaison et l'utilisation des hooks générés pour interroger et muter les données. RTK Query simplifie la récupération de données et la gestion de l'état avec un minimum de code, ce qui en fait un outil puissant pour les applications Redux modernes.
다음 부분에서는 쿼리 사용자 정의, baseQuery 사용, 인증 처리, 성능 최적화 등 RTK 쿼리의 고급 주제에 대해 자세히 살펴보겠습니다.
4부: RTK 쿼리의 고급 주제를 계속 지켜봐주세요!
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!