Vue3 中有些场景,真不想用 Pinia !

开发 前端
在 react 中使用 swr、react-query 是大势所趋,可以从 npm 下载量来看出来。相信今后在 vue 中 vue-query 也会有越来越多的使用,因为另外三大框架都是跟随 react 走的 hooks 的思想。

大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心~

背景

图片图片

Pinia 现阶段是 Vue3 最火的一个状态管理库了,很多人用 Pinia 来:

  • 缓存一些请求回来的数据
  • 管理一些可以全局共用的数据

其实最重要的一点就是:缓存一些请求回来的数据

毕竟,前端只是静态页面,你得需要去请求数据,才能让你的页面动态去展示你想展示的东西

就比如我想要通过请求去获取登录用户的用户信息,并展示在页面,那么在 Pinia 中我会这么写

图片图片

并且在页面中去调用对应的请求方法,获取数据,并且如果需要在请求过程中加一个过渡的 loading 阶段的话,那么还需要再页面中去维护几个 loading 变量,以达到我们想要的目的

图片图片

其实这是非常麻烦的一件事,那如果有十个页面,岂不是就得维护几十个 loading 变量?这其实是很多开发者非常苦恼的事情

vue-query

其实不一定所有场景都用到 Pinia,其实我们想要的目的很简单:数据缓存 + loading

那么有什么办法能让我们缓存请求的数据,又能不用我们自己维护 loading 变量呢?

或许我们可以试试 vue-query 这个库

pnpm i vue-query

在 main.ts 中去注册全局

图片图片

接着在页面中使用,可以看到,我故意在页面中去写两次请求

图片图片

但是他会有缓存效果,实际只发了一次请求,那是因为 useQuery 第一个参数是传一个 key ,这个 key 会标识请求的唯一性,你想要请求两次的话,可以把 key 设置成不一样的即可~

图片图片

总结

先来看看官方文档中怎么说:https://tanstack.com/query/v4/docs/framework/vue/guides/does-this-replace-client-state

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

趋势

在 react 中使用 swr、react-query 是大势所趋,可以从 npm 下载量来看出来。相信今后在 vue 中 vue-query 也会有越来越多的使用,因为另外三大框架都是跟随 react 走的 hooks 的思想。

责任编辑:武晓燕 来源: Go语言圈
相关推荐

2024-03-01 11:32:22

Vue3APIVue.js

2021-12-16 08:47:56

Vue3 插件Vue应用

2024-04-08 07:28:27

PiniaVue3状态管理库

2024-04-10 08:27:32

PiniaVue3持久化插件

2021-12-31 07:48:58

Vue3 插件Vue应用

2022-03-07 11:15:25

Pinia状态库vue3

2021-12-01 08:11:44

Vue3 插件Vue应用

2021-11-30 08:19:43

Vue3 插件Vue应用

2022-02-22 07:37:26

VuePinia态管理库

2023-11-28 09:03:59

Vue.jsJavaScript

2021-07-29 07:51:43

工具 HappensBefore

2021-08-11 11:25:22

happens - bJava代码

2020-09-19 21:15:26

Composition

2021-12-02 05:50:35

Vue3 插件Vue应用

2013-05-20 16:30:37

移动应用App推广

2021-11-16 08:50:29

Vue3 插件Vue应用

2022-03-10 11:04:04

Vue3Canvas前端

2021-05-26 10:40:28

Vue3TypeScript前端

2021-12-08 09:09:33

Vue 3 Computed Vue2

2022-06-21 12:09:18

Vue差异
点赞
收藏

51CTO技术栈公众号