首页 > 其他分享 >TanStack Query 使用总结

TanStack Query 使用总结

时间:2023-02-25 00:44:05浏览次数:37  
标签:总结 const dataSourceQuery api 查询 useQuery TanStack Query getUseList

TanStack Query使用总结

TanStack Query 是一个开源、功能齐全、支持 TypeScript 的库,它支持React,Vue,Svelte,Solid框架
非常适合用于处理客户端状态,处理异步或服务器状态。它非常好用,开箱即用,无需配置,并且可以随着应用的增长而根据自己的喜好进行定制。

查询 Queries

至少需要二个参数

  • 查询唯一键值
  • 一个Promise 的函数

用例:

queryKey和要调用的promise方法可以不用对象的形式包裹传入,直接直接以多个参数的方式传入

多个参数形式传入

const dataSourceQuery = useQuery(['dataSourceQuery'],  () => api.getUseList())

参数用一个对象形式传入

const dataSourceQuery = useQuery({ queryKey: ["dataSourceQuery"], queryFn: api.getUseList })

查询后直接获取参数和状态

 const { isLoading, isError, data, error } = useQuery(['dataSourceQuery'],  () => api.getUseList())
 console.log('isLoading, isError, data, error---',isLoading, isError, data, error)

由于 Vue Query 的获取机制不可知地(agnostically)建立在 Promises 上,因此您可以将 Vue Query 与字面上的任何异步数据获取客户端(包括 GraphQL)一起使用!

const dataSourceQuery = useQuery(['dataSourceQuery'],  async () => {
 return await api.getUseList()
})

result对象包含一些非常重要的状态

  • isLoading 或者 status === 'loading' - 查询暂时还没有数据

  • isError 或者 status === 'error' - 查询遇到一个错误

  • isSuccess 或者 status === 'success' - 查询成功,并且数据可用

  • 除了这些主要状态之外,取决于具体查询的状态,还有更多信息可用:

  • error - 如果查询处于isError状态,则可以通过error属性获取该错误

  • data - 如果查询处于success状态,则可以通过data属性获得数据

查询的键值

Vue Query 在内部基于查询键值来管理查询缓存。 传递给 Vue Query 的查询键值必须是一个数组。
查询功能依赖于变量,则将其包含在查询键值中

const dataSourceQuery = useQuery(['dataSourceQuery',userId],  async () => {
    return await api.getUseList()
})

依赖查询

使用enabled来进行依赖查询

多个参数形式传入

const dataSourceQuery = useQuery(['dataSourceQuery'],  () => api.getUseList(),{enabled: !!userId})

参数用于一个对象形式传入

const dataSourceQuery = useQuery({
    queryKey: ["dataSourceQuery"], queryFn: ()=> api.getUseList(),enabled: !!userId
})

查询重试

当useQuery查询失败(查询函数引发错误)时,如果该查询的请求未达到最大连续重试次数(默认 3 次

  • 设置retry = false将禁用重试

  • 设置retry = 6该函数抛出最终错误前,将重试 6 次

  • 设置retry = true将无限次重试失败的请求

  • 设置retry =(failureCount,error)=> ...允许基于请求失败的原因进行自定义逻辑

多个参数形式传入

const dataSourceQuery = useQuery(['dataSourceQuery'],  () => api.getUseList(),{enabled: !!userId,retry: 6})

对象形式传入

const dataSourceQuery = useQuery({
  queryKey: ["dataSourceQuery"], queryFn: ()=> api.getUseList(),enabled: !!userId,retry: 6
})

重试延迟
默认情况下,React Query 不会在请求失败后立即重试。按照标准,后退延迟将逐渐应用于每次重试。
默认的retryDelay设置为以二的倍数递增(从1000ms开始),但不超过 30 秒:

// 为所有查询配置
import { VueQueryPlugin } from "@tanstack/vue-query";

const vueQueryPluginOptions = {
  queryClientConfig: {
    defaultOptions: {
      queries: {
        retryDelay: (attemptIndex) => Math.min(1000 * 2 ** attemptIndex, 30000),
      },
    },
  },
};
app.use(VueQueryPlugin, vueQueryPluginOptions);

单个查询设置

const dataSourceQuery = useQuery(['dataSourceQuery'],  () => api.getUseList(),{
  enabled: !!userId,
  retry: 6,
  retryDelay: 1000, // 无论重试多少次,都会始终等待1000毫秒然后重试
})

分页/滞后查询

常用分页的UI会在success和loading状态之间来回跳转,因为每个新页面都被视为一个全新的查询。这种体验并不是最佳的,
Vue Query 带有一个称为keepPreviousData的强大功能,从而使得这个问题可以被轻易的解决。

使用keepPreviousData的更好的分页查询

通过将keepPreviousData设置为true,我们可以得到一些新的东西:

  • 请求新数据时,即使查询键值已更改,上次成功获取的数据仍可用

  • 当新数据到达时,先前的数据将被无缝交换以显示新数据

  • 可以使用isPreviousData来了解当前查询提供的是什么数据

const dataSourceQuery = useQuery(['dataSourceQuery'],  () => api.getUseList(),{
  keepPreviousData: true,
})

预取数据

如果对用户将做的事情有足够的了解,以便能够在需要之前预取他们所需的数据!
在这种情况下,可以使用prefetchQuery方法预取要放入缓存的查询结果:

const prefetchTodos = async () => {
  // 该查询的结果将像普通查询一样被缓存
  await queryClient.prefetchQuery(["dataSourceQuery"], api.getUseList);
};
  • 如果此查询的数据已经在缓存中并且没有失效,则将不会获取该数据
  • 如果一个staleTime被传递,例如:prefetchQuery(['todos'], fn, {staleTime:5000}),当数据早于指定的 staleTime 时,则查询将去尝试获取新值
  • 如果一个预取的查询没有出现useQuery实例,则将在cacheTime指定的时间之后被删除并被垃圾回收

添加或更新查询的缓存结果。

queryClient.setQueryData(["todos"], todos);

标签:总结,const,dataSourceQuery,api,查询,useQuery,TanStack,Query,getUseList
From: https://www.cnblogs.com/zimengxiyu/p/17153631.html

相关文章

  • 打卡App关于每日总结打卡内容的实现(大概,写的巨烂,惨不忍睹
      首先我的项目结构是登录页面、注册页面、添加打卡信息页面、打卡信息展示页面关于坚持天数和连续坚持的天数,我这里使用了SharePrefence共享参数的方式,导致代码很冗......
  • 开课总结
    本周周一,老师给我们布置下了本学期的目标,由此开始我的专业正式迈入正轨,开始学习软件的制作与开发。在课上老师布置任务时,我深刻感受到了本学期的学习压力,尤其是在我上一学......
  • 2月24日总结
    所花时间:10节课,学习概率论,计算机网络代码量:0行今日的课非常多,原本是12节课,整整一天都有课,庆幸的是下午前两节老师有事情取消了上课,让我今天有了一丝丝喘息的机会,写了写作......
  • 今日总结2023/02/23
    今日学习了按钮控件的制作1.新建module2.找到activity_main.xml(首先项目内要有TextView)<?xmlversion="1.0"encoding="utf-8"?><LinearLayoutxmlns:android="http://......
  • jQuery插件-fullpage全屏幻灯片展示效果
    fullpage全屏插件全屏滚动效果,原生js也很好实现,主要是用mousewheel鼠标滚轮滚动事件,来判断上滚动还是下滚动,之后设置每次滚动的高度为屏幕的高度即可。但是,虽然效果简......
  • 关于SQLsever2012报错的一些经验总结
    问题描述:数据库连接实例时出现报错情况;问题截图:  故障软件:SQLsever2012操作系统:windowssever2022R2数据中心期望结果:可以打开之前的实例 总结经验: 上面这......
  • 每日总结(5)
    所用时间:晚上2小时代码:0博客:0知识点:axiox:网络请求1、利用npm安装: npminstallaxios1、get请求//get请求方式一:axios({//默认请求方式为get......
  • 每日总结-23.2.24
    今天主要学习了一些关于androidstudio的用法match_parent适配整个容器wrap_parent适配textview里面的东西TextViewTvone=findViewById(R.id.TeV);//通过id找到xml里......
  • 2023.2.24每日总结
    今天主要学了怎么传值和登录界面的制作登录界面XML<?xmlversion="1.0"encoding="utf-8"?><LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"......
  • 每日总结5(2.24)
    今日时间安排满满,整整上了一天的课,认真学了了一整天, 基本都是考研的科目,课程非常重要,同时,学习的结果收获满满,今日课程有,早上八点的计算机网络课,课程上进行了一次课程小......