”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何使用 React Query 设置 Expo React Native 项目

如何使用 React Query 设置 Expo React Native 项目

发布于2024-10-31
浏览:391

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

与外部 API 交互通常是必不可少的,React Query 允许您专注于数据而不是获取数据的复杂性,从而简化了这一点。本指南将引导您使用 Expo 设置 React Native 项目并将其与 React Query 集成。

第 1 步:设置您的世博项目

首先,安装 Expo CLI 并创建一个新项目。如果您已有项目,请跳至下一步。

  • 安装 Expo CLI
  npm install -g expo-cli
  • 创建一个新项目
  expo init my-react-native-query-app

根据您的需求选择模板。

第 2 步:安装 React 查询和依赖项

React Query 对于管理 React Native 应用程序中的服务器状态非常强大。

  • 安装 React Query
  npm install @tanstack/react-query
  • 安装附加依赖项
  npx expo install @react-native-community/netinfo

第 3 步:创建辅助函数

在项目根目录的 hooks 文件夹中创建三个自定义挂钩。

  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);
     });
   });

这会在应用程序重新连接到互联网时启用自动重新获取。

  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();
   }, []);

这会在应用程序处于活动状态时更新应用程序状态。

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

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

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

         refetch();
       }, [refetch]),
     );
   }

当屏幕聚焦时,此自定义挂钩会触发重新获取。

第四步:实现根文件中的函数

在您的主路线文件中,设置以下内容:

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 (
    
      {Rest of your project}
    
  );
}

第 5 步:启动您的开发服务器

导航到您的项目目录并启动 Expo 开发服务器:

expo start

Expo 允许通过 Expo Go 应用程序或构建开发应用程序进行快速测试。有关创建开发版本的更多详细信息,请参阅 Expo 的文档。

结论

使用 React Query 设置 Expo React Native 项目可以简化状态管理和 API 交互。通过利用 React Query 的强大功能(例如缓存和后台更新),您可以更多地关注数据,而不是复杂的获取数据。

快乐编码! ??‍? ??‍? ?

版本声明 本文转载于:https://dev.to/hokagedemehin/how-to-set-up-an-expo-react-native-project-with-react-query-3oeb?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何使用现代 CSS 将按钮无缝集成到输入字段中?
    如何使用现代 CSS 将按钮无缝集成到输入字段中?
    如何使用现代 CSS 将按钮集成到输入中问题:创建视觉元素其中按钮无缝集成在输入字段中,允许正常的用户交互、保留文本可见性并保持可访问性和屏幕阅读器兼容性。解决方案:Flexbox 和表单边框最佳方法是使用弹性盒布局以及包含元素(表单)上的边框:定位:设置具有水平行布局的弹性盒,允许输入扩展以填充可...
    编程 发布于2024-11-07
  • 内核开发中的 C++:综合指南
    内核开发中的 C++:综合指南
    介绍 由于直接硬件访问和最小的运行时开销,内核开发传统上是 C 的领域。然而,由于其面向对象的特性,C 在内核编程中找到了自己的位置,这可以带来更干净、更易于维护的代码。本指南将逐步介绍如何使用 C 进行内核开发,重点是设置环境、构建项目以及使用 C 功能编写内核代码,同时牢记内核...
    编程 发布于2024-11-07
  • 在 React 项目中实现 CSS 模块
    在 React 项目中实现 CSS 模块
    React 中的 CSS 模块是一种通过自动生成唯一类名来确定 CSS 范围的方法。这可以防止大型应用程序中的类名冲突并允许模块化样式。以下是如何在 React 项目中使用 CSS 模块: 1. 设置 默认情况下,React 支持 CSS 模块。您只需使用扩展名 .module.cs...
    编程 发布于2024-11-07
  • 有哪些资源可用于实现彗星模式?
    有哪些资源可用于实现彗星模式?
    Comet:服务器推送模式服务器推送是一种在服务器和 Web 客户端之间实现双向通信的技术,已经获得了显着的成果最近的兴趣。 Comet 设计模式作为在 JavaScript 应用程序中实现服务器推送的一种有前途的方法而出现。本问题探讨了 Comet 模式的 jQuery 实现和通用资源的可用性。j...
    编程 发布于2024-11-07
  • 探索心理健康门诊项目的类型
    探索心理健康门诊项目的类型
    门诊心理健康治疗方法是一种不强调在医疗机构过夜的方案。这种疗法主要在医生办公室、医院或诊所提供,在那里人们可以进行定期治疗,以进行高度结构化的定期治疗。 在 COVID-19 大流行期间,全球约有 2.75 亿吸毒者。比前几十年高出近 22%。吸毒成瘾的增加导致全美吸毒过量人数创历史新高。好消息是门...
    编程 发布于2024-11-07
  • 如何在 C++ Builder 中初始化 OpenGL 帧:分步指南
    如何在 C++ Builder 中初始化 OpenGL 帧:分步指南
    如何在 C Builder 中初始化 OpenGL 帧在 C Builder 中的窗体内初始化 OpenGL 帧可能是一项具有挑战性的任务。在尝试调整现有 OpenGL 代码(例如问题中提供的示例)时,您可能会遇到困难。要正确创建和渲染 OpenGL 帧,请按照下列步骤操作:使用 TForm::Ha...
    编程 发布于2024-11-07
  • 利用这些罕见的 HTML 属性增强您的 Web 开发技能
    利用这些罕见的 HTML 属性增强您的 Web 开发技能
    Introduction HTML attributes are most often referred to as the overlooked heroes of web development, playing a crucial role in shaping the st...
    编程 发布于2024-11-07
  • 如何在 Python 中将字符串转换为二进制:ASCII 与 Unicode?
    如何在 Python 中将字符串转换为二进制:ASCII 与 Unicode?
    在Python中将字符串转换为二进制在Python中,您可能会遇到需要将字符串表示为二进制数字序列的情况。这对于多种原因都很有用,例如数据加密或二进制文件操作。使用 bin() 函数将字符串转换为二进制的最简单方法就是使用bin()函数。该函数接受一个字符串作为输入,并将其二进制表示形式返回为字符串...
    编程 发布于2024-11-07
  • 为什么从 Java 中的匿名内部类访问外部实例变量需要是 Final?
    为什么从 Java 中的匿名内部类访问外部实例变量需要是 Final?
    Java内部类:为什么必须使用“最终”外部实例变量在Java中定义匿名内部类时,您可能会遇到将外部实例变量标记为“final”的要求。本文探讨了这个约束背后的原因。正如提供的代码中提到的,实例变量 jtfContent 必须声明为 Final 才能在内部类中访问。这一要求源于 Java 处理匿名内部...
    编程 发布于2024-11-07
  • 理解 Python 中的关键字参数
    理解 Python 中的关键字参数
    When you're programming in Python, knowing how to pass arguments to functions is key for writing clear, flexible, and easy-to-maintain code. One powe...
    编程 发布于2024-11-07
  • 如何防止打印时DIV跨页拆分?
    如何防止打印时DIV跨页拆分?
    打印问题:防止 DIV 跨页面分叉遇到动态 DIV 在页面之间切成两半的打印困境?当尝试打印具有大量可变高度 DIV 元素的冗长文档时,就会出现此问题。CSS 救援解决方案为了解决此问题,CSS 属性打破了 -里面来拯救。通过指定值避免,您可以确保渲染引擎防止 DIV 中途分割。这是代码片段:@me...
    编程 发布于2024-11-07
  • Python 是强类型语言吗?
    Python 是强类型语言吗?
    Python 是强类型语言吗?Python 中的强类型概念引起了一些混乱,因为该语言允许变量改变执行期间的类型。然而,Python 确实是强类型的,尽管是动态的。Python 中的强类型强类型可确保值保持其声明的类型,除非显式转换。在Python中,这意味着变量没有固定的类型,而是它们所保存的值有类...
    编程 发布于2024-11-07
  • 购买亚马逊评论
    购买亚马逊评论
    https://dmhelpshop.com/product/buy-amazon-reviews/ 购买亚马逊评论 当谈到在亚马逊上进行商务和销售产品时,评论的重要性怎么强调都不为过。一条评论就可以决定购买的成败,而潜在的买家往往会犹豫是否购买缺乏评论的产品。缺乏评论可以起到威慑作用,这就是为什么...
    编程 发布于2024-11-07
  • 使用 DTO 简化 Laravel 中的数据传输
    使用 DTO 简化 Laravel 中的数据传输
    这是有关如何使用 Laravel Data: 创建数据传输对象 (DTO) 的分步示例 1. 安装Laravel数据包 首先,使用 Composer 安装 spatie/laravel-data 包。该软件包有助于创建 DTO 并有效管理数据。 composer require sp...
    编程 发布于2024-11-07

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3