Maison > interface Web > js tutoriel > Comment configurer un projet natif Expo React avec React Query

Comment configurer un projet natif Expo React avec React Query

PHPz
Libérer: 2024-09-01 21:03:02
original
651 Les gens l'ont consulté

How to Set Up an Expo React Native Project with React Query

Interagir avec des API externes est souvent essentiel, et React Query simplifie cela en vous permettant de vous concentrer sur les données plutôt que sur la complexité de leur récupération. Ce guide vous guidera dans la configuration d'un projet React Native à l'aide d'Expo et dans son intégration avec React Query.

Étape 1 : Configurez votre projet d'exposition

Pour commencer, installez Expo CLI et créez un nouveau projet. Si vous avez déjà un projet, passez à l'étape suivante.

  • Installer Expo CLI :
  npm install -g expo-cli
Copier après la connexion
  • Créer un nouveau projet :
  expo init my-react-native-query-app
Copier après la connexion

Choisissez un modèle en fonction de vos besoins.

Étape 2 : Installer la requête et les dépendances de React

React Query est puissant pour gérer l'état du serveur dans vos applications React Native.

  • Installer React Query :
  npm install @tanstack/react-query
Copier après la connexion
  • Installer des dépendances supplémentaires :
  npx expo install @react-native-community/netinfo
Copier après la connexion

Étape 3 : Créer des fonctions d'assistance

Créez trois hooks personnalisés dans un dossier hooks à la racine de votre projet.

  1. useAppState.ts :
   import NetInfo from '@react-native-community/netinfo';
   import { onlineManager } from '@tanstack/react-query';

   onlineManager.setEventListener((setOnline) => {
     return NetInfo.addEventListener((state) => {
       setOnline(!!state.isConnected);
     });
   });
Copier après la connexion

Cela permet la récupération automatique lorsque l'application se reconnecte à Internet.

  1. UseOnlineManager.ts :
   import { useEffect } from 'react';
   import { AppState, Platform } from 'react-native';
   import { focusManager } from '@tanstack/react-query';

   function onAppStateChange(status: AppStateStatus) {
     if (Platform.OS !== 'web') {
       focusManager.setFocused(status === 'active');
     }
   }

   useEffect(() => {
     const subscription = AppState.addEventListener('change', onAppStateChange);
     return () => subscription.remove();
   }, []);
Copier après la connexion

Cela met à jour l'état de l'application lorsque l'application est active.

  1. useRefreshOnFocus.ts :
   import React from 'react';
   import { useFocusEffect } from '@react-navigation/native';

   export function useRefreshOnFocus<T>(refetch: () => Promise<T>) {
     const firstTimeRef = React.useRef(true);

     useFocusEffect(
       React.useCallback(() => {
         if (firstTimeRef.current) {
           firstTimeRef.current = false;
           return;
         }

         refetch();
       }, [refetch]),
     );
   }
Copier après la connexion

Ce hook personnalisé déclenche une récupération lorsque l'écran est mis au point.

Étape 4 : implémentez les fonctions dans votre fichier racine

Dans votre fichier de route principal, configurez les éléments suivants :

import {
  QueryClient,
  QueryClientProvider,
  focusManager,
} from "@tanstack/react-query";
import { AppStateStatus, Platform } from "react-native";
import { useOnlineManager } from "@/hooks/query/useOnlineManager";
import { useAppState } from "@/hooks/query/useAppState";

export default function RootLayout() {
  function onAppStateChange(status: AppStateStatus) {
    if (Platform.OS !== "web") {
      focusManager.setFocused(status === "active");
    }
  }

  const queryClient = new QueryClient({
    defaultOptions: { queries: { retry: 2 } },
  });

  useOnlineManager();
  useAppState(onAppStateChange);

  return (
    <QueryClientProvider client={queryClient}>
      {Rest of your project}
    </QueryClientProvider>
  );
}
Copier après la connexion

Étape 5 : démarrez votre serveur de développement

Accédez au répertoire de votre projet et démarrez le serveur de développement Expo :

expo start
Copier après la connexion

Expo permet des tests rapides via l'application Expo Go ou en créant une application de développement. Pour plus de détails sur la création d'une version de développement, reportez-vous à la documentation d'Expo.

Conclusion

La mise en place d'un projet Expo React Native avec React Query simplifie la gestion des états et les interactions API. En tirant parti des fonctionnalités puissantes de React Query, telles que la mise en cache et les mises à jour en arrière-plan, vous pouvez vous concentrer davantage sur vos données et moins sur les subtilités de leur récupération.

Bon codage ! ???‍? ???‍? ?

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:dev.to
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