vue-query的使用

 vue-query,类似于vuex/pinia,以缓存为目的,但侧重的是对网络请求的缓存。
这是我预想的使用场景:假设在各个页面都需要发起相同的请求,去获取数据,而这种数据在一定时间内不会发生变化,那么这种请求数据是可以被缓存下来的。

pinia用于处理公共状态,vue-query用于处理服务端状态,准确的说是把原本需要在pinia中处理的服务端状态迁移到vue-query中。

本实例使用的vue版本是3.3.0

vue-query

github地址:DamianOsipiuk/vue-query: Hooks for fetching, caching and updating asynchronous data in Vue (github.com)

1、安装vue-query

npm i vue-query 

2、在入口文件中引入

import { VueQueryPlugin } from 'vue-query'
import { createApp } from 'vue'

import router from './router'

import App from './App.vue'
const app = createApp(App)
app.use(router)
app.use(VueQueryPlugin);

app.mount('#app')

3、使用

index.vue

<template>
  <div>
首页
{{ isLoading }}
<showList/>
<button @click="goAbout">去about页面</button>
  </div>
</template>

<script setup lang="ts">
import {ref} from 'vue'
import ajax from '@/common/ajax'
import {useQuery} from 'vue-query';
import {useRouter} from 'vue-router'
import showList from '@/components/showList.vue';
const router = useRouter();
const getData = ()=>{
//这里使用的是node写的接口服务,自行替换自己的接口
  return ajax('/live/api/packages/list');
}
const goAbout = ()=>{
  router.push('/about')
}
const {data,isLoading} = useQuery(["listData"], ()=>getData());

</script>

<style scoped>

</style>

components/showList.vue

<template>
    <div>
        <h2>列表组件</h2>
        <ul>
            <li v-for="packages in packageList" :key="packages._id">{{ packages.name }}</li>
        </ul>
    </div>
</template>

<script setup lang="ts">
import { computed } from 'vue'
import { useQuery } from 'vue-query';

const {data} = useQuery(["listData"]);


const packageList = computed(() => data.value?.data.data.list);


</script>

<style scoped></style>

效果展示

可以看到组使用 listData的缓存数据

接下来在首页跳转到about页面,在about页面也使用这份缓存数据

about.vue

<template>
  <div>
    <h2>About页面使用缓存数据</h2>
    <ul>
      <li v-for="packages in packageList" :key="packages._id">{{ packages.name }}</li>
    </ul>
    </div>
</template>
 
<script setup lang="ts">
import { computed } from 'vue'

import { useQuery } from 'vue-query';
const { data } = useQuery(["listData"]);

const packageList = computed(() => data.value?.data.data.list);

</script>
 
<style scoped></style>

效果展示

 跳转到about页面,是没有重新发送请求的,使用的是之前的缓存数据

但是发现在页面重新获取焦点和切换路由后,会重新发送请求,看文档说以下添加配置,但是发现不起效

const {data,isLoading} = useQuery(["listData"], ()=>getData(),{
    cacheTime: Infinity,
    staleTime: Infinity,
});

 

vue-query

@tanstack/vue-query

@tanstack/vue-query可以说是vue-query的强化版本,TanStack Query 是一个开源、功能齐全、支持 TypeScript 的库,非常适合用于处理客户端状态,处理异步或服务器状态。它支持React,Vue,Svelte,Solid框架,大多时候我们都会我们使用的框架把它叫做vue-query或者react-query。

特点

  • 非常好用的query库,目的是为了缓存后端api的结果,不用像以前一样,手动将结果一个一个存储到store,并且提供了一些非常好用的hook方法
  • 非常适合用于处理客户端状态,处理异步或服务器状态
  • 默认支持异步
  • 它并不是用于替代axios等请求库,而只是作为外层的封装,方便控制请求与结果

安装:

npm i @tanstack/vue-query

 在入口文件注册

import { VueQueryPlugin } from '@tanstack/vue-query'
app.use(VueQueryPlugin);

复用上面的代码,只需要将vue-query改为@tanstack/vue-query

index.vue

<template>
  <div>
    首页
    {{ isLoading }}
    <!-- {{ data }} -->
    <!-- {{ datas }} -->
    <showList />
    <button @click="goAbout">去about页面</button>
  </div>
</template>

<script setup lang="ts">

import ajax from '@/common/ajax'
import { useQuery } from '@tanstack/vue-query';

import { useRouter } from 'vue-router'
import showList from '@/components/showList.vue';
const router = useRouter();

const getData = () => {


  return ajax('/live/api/packages/list');
}

const goAbout = () => {
  router.push('/about')
}


const { data, isLoading } = useQuery({
  queryKey: ['listData'],
  queryFn: () => getData(),
  
});

</script>

<style scoped></style>

components/showList.vue

<template>
    <div>
        <h2>列表组件</h2>
        <ul>
            <li v-for="packages in packageList" :key="packages._id">{{ packages.name }}</li>
        </ul>
    </div>
</template>

<script setup lang="ts">
import { computed } from 'vue'
import {useQuery} from '@tanstack/vue-query';


const { data } = useQuery({
    queryKey: ['listData']
});

const packageList = computed(() => data.value?.data.data.list);


</script>

<style scoped></style>

about.vue

<template>
  <div>
    <h2>About页面使用缓存数据</h2>
    <ul>
      <li v-for="packages in packageList" :key="packages._id">{{ packages.name }}</li>
    </ul>
    </div>
</template>
 
<script setup lang="ts">
import { computed } from 'vue'

import { useQuery } from '@tanstack/vue-query';
const { data } = useQuery({
  queryKey:["listData"]
});

const packageList = computed(() => data.value?.data.data.list);

</script>
 
<style scoped></style>

设置refetchInterval,在规定间隔中重新发送请求

const { data, isLoading } = useQuery({
  queryKey: ['listData'],
  queryFn: () => getData(),
  refetchInterval: 12000
});

可以看到network会重新发送请求

@tanstack/vue-query

总结

vue-query 只适用于存储从服务端获取的数据,如果有另外的数据需要存储还是要用到 pinia,但是这种数据是比较少的,这样也可以使得 pinia 中的代码量减少很多并简洁。当然这里介绍的 vue-query 的 api 是最简单的,你能想到的功能它基本都有,感兴趣的可以查看文档。

Vue-router是一个vue.js官方的路由管理插件,它可以方便我们实现单页应用中的路由转换。它提供了路由导航的钩子函数,在路由转换前可以执行一些逻辑。Vue-router中有两种路由参数,分别为param和query。param参数是基于URL的占位符参数,而query参数则是基于查询字符串的参数。 对于param参数,我们可以在路由路径中通过使用冒号(:)来设置。例如,我们可以设置一下的路由路径: ``` { path: '/user/:id', component: User } ``` 这里的:id表示的是一个动态占位符,可以通过$route.params来获取路由参数。例如,我们可以在组件中通过this.$route.params.id来获取到当前路由的id参数值。 而对于query参数,我们可以通过在路由路径后加上查询字符串的方式来设置。例如: ``` { path: '/user', component: User } ``` 然后我们可以在我们的应用中通过像这样访问路由: ``` http://example.com/user?id=1 ``` 这里的id就是一个query参数,并且可以在组件中通过this.$route.query.id来获取到当前路由中的查询参数。 在使用Vue-router时,我们需要通过路由配置来设置param和query参数的处理方式。例如,我们可以在路由配置中通过props属性来将路由参数传递给组件,或者通过beforeEach方法来在路由跳转前对参数进行处理。 总之,Vue-router的param和query参数可以方便我们实现单页应用中复杂的路由转换,并且提供了一些处理方式来方便我们对参数进行管理。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值