200React-Query基础

一、导入使用

js 复制代码
pnpm add @tanstack/react-query

二、以往请求接口

js 复制代码
import {useEffect, useState} from 'react'
import { fetchDate } from '../helper'
import { List} from '../List'

function Demo(){
	const [data, setData] = useState([]);
	const initialDate = async() =>{
	try {
		steDate(await fetchDate('people)
		}
	catch(err){
		console.error(err)
		}
}
	useEffect(() => {
		initialDate()
		},[]
	);
	return <List item={data}/>
}

缺点:

缺点 详细描述 TanStack Query 如何解决
1. 冗余的状态管理(Loading/Error/Data) 必须在组件内使用多个 useState 来分别跟踪数据 (data)、加载状态 (isLoading) 和错误状态 (isError/error),导致代码繁琐且易错。 "useQuery Hook 直接提供所需的所有状态,如 isLoading, isError, data, error 等,极大地简化了组件逻辑。"
2. 缺乏智能缓存和数据过期机制 每次组件挂载或路由切换时都会触发重新请求,即使数据在短时间内并未改变,浪费带宽和用户时间。 强大的自动缓存机制,根据设置的过期时间(staleTime)快速返回缓存数据,并在后台按需更新,避免不必要的网络请求。
3. 难以保持数据的"新鲜度" 切换浏览器标签页回来后,或者网络连接恢复后,您需要手动编写逻辑来检查并重新拉取数据,以确保用户看到的是最新数据。 默认内置了窗口重新聚焦(Refetch on Window Focus)和网络重连时自动重试功能,自动维护数据的时效性。
4. 全局数据共享复杂 多个组件需要使用相同数据时,必须通过 Props Driling 或 Redux 等全局状态管理库来实现共享,且缓存管理和异步操作的管理变得非常复杂。 通过**查询键(queryKey)**全局缓存数据,任何组件都可以轻松地通过相同的键访问和共享这份数据。
5. 实现乐观更新(Optimistic Updates)难度大 对于数据的增删改操作(Mutation),为了提升用户体验而实现的"乐观更新"(在服务器响应前更新 UI)非常复杂且容易引入 Bug。 useMutation Hook 提供了清晰的生命周期回调,使得实现乐观更新、错误回滚等逻辑变得简单和安全。

三、使用useQuery

js 复制代码
import { useQuery } from '@tanstack/react-query'
import { fetchDate } from '../helper'
import { List } from '../List'



function DemoWithQuery() {
  const { 
    data, 
    isLoading, // 自动管理加载状态
    isError,   // 自动管理错误状态
    error      // 错误对象
  } = useQuery({
    // 数据的唯一标识符,用于缓存
    queryKey: ['peopleData'], 
    // 实际执行数据获取的函数
    queryFn: ()=> fetchData('people'),
    // (可选) 设置数据多久后变为"陈旧"(stale),默认为 0
    // staleTime: 1000 * 60 * 5, // 5分钟内数据被认为是"新鲜"的
  });

  if (isLoading) {
    return <div>数据加载中...</div>
  }

  if (isError) {
    // 错误信息可以直接从 error 对象中获取
    console.error(error);
    return <div>数据加载失败: {error.message}</div>
  }

  // 直接使用获取到的 data
  return <List item={data} />
}
相关推荐
ssshooter17 分钟前
复古话题:Vue2 的空格间距切换到 Vite 后消失了
前端·vue.js·面试
IamZJT_23 分钟前
拒绝做 AI 的“饲养员” ❌:前端程序员在 AI 时代的生存与进化指南 🚀
前端·ai编程
MM_MS27 分钟前
Halcon控制语句
java·大数据·前端·数据库·人工智能·算法·视觉检测
程序员Agions38 分钟前
程序员武学修炼手册(二):进阶篇——小有所成,从能跑就行到知其所以然
前端·程序员
小画家~42 分钟前
第四十六: channel 高级使用
java·前端·数据库
小贵子的博客1 小时前
Ant Design Vue <a-table>
前端·javascript·vue.js·anti-design-vue
m0_502724951 小时前
vue动态设置背景图片后显示异常
前端·css
console.log('npc')1 小时前
vue2中子组件父组件的修改参数
开发语言·前端·javascript
奋斗吧程序媛1 小时前
vue3 Study(1)
前端·javascript·vue.js
@Autowire1 小时前
Layout-position
前端·css