当前位置:首页 > 科技  > 软件

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

来源: 责编: 时间:2024-04-02 17:18:52 235观看
导读大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心~背景图片Pinia 现阶段是 Vue3 最火的一个状态管理库了,很多人用 Pinia 来:缓存一些请求回来的数据管理一些可以全局共用的数据

大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心~5GV28资讯网——每日最新资讯28at.com

背景

图片图片5GV28资讯网——每日最新资讯28at.com

Pinia 现阶段是 Vue3 最火的一个状态管理库了,很多人用 Pinia 来:5GV28资讯网——每日最新资讯28at.com

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

其实最重要的一点就是:缓存一些请求回来的数据5GV28资讯网——每日最新资讯28at.com

毕竟,前端只是静态页面,你得需要去请求数据,才能让你的页面动态去展示你想展示的东西5GV28资讯网——每日最新资讯28at.com

就比如我想要通过请求去获取登录用户的用户信息,并展示在页面,那么在 Pinia 中我会这么写5GV28资讯网——每日最新资讯28at.com

图片图片5GV28资讯网——每日最新资讯28at.com

并且在页面中去调用对应的请求方法,获取数据,并且如果需要在请求过程中加一个过渡的 loading 阶段的话,那么还需要再页面中去维护几个 loading 变量,以达到我们想要的目的5GV28资讯网——每日最新资讯28at.com

图片图片5GV28资讯网——每日最新资讯28at.com

其实这是非常麻烦的一件事,那如果有十个页面,岂不是就得维护几十个 loading 变量?这其实是很多开发者非常苦恼的事情5GV28资讯网——每日最新资讯28at.com

vue-query

其实不一定所有场景都用到 Pinia,其实我们想要的目的很简单:数据缓存 + loading5GV28资讯网——每日最新资讯28at.com

那么有什么办法能让我们缓存请求的数据,又能不用我们自己维护 loading 变量呢?5GV28资讯网——每日最新资讯28at.com

或许我们可以试试 vue-query 这个库5GV28资讯网——每日最新资讯28at.com

pnpm i vue-query

在 main.ts 中去注册全局5GV28资讯网——每日最新资讯28at.com

图片图片5GV28资讯网——每日最新资讯28at.com

接着在页面中使用,可以看到,我故意在页面中去写两次请求5GV28资讯网——每日最新资讯28at.com

图片图片5GV28资讯网——每日最新资讯28at.com

但是他会有缓存效果,实际只发了一次请求,那是因为 useQuery 第一个参数是传一个 key ,这个 key 会标识请求的唯一性,你想要请求两次的话,可以把 key 设置成不一样的即可~5GV28资讯网——每日最新资讯28at.com

图片图片5GV28资讯网——每日最新资讯28at.com

总结

先来看看官方文档中怎么说:https://tanstack.com/query/v4/docs/framework/vue/guides/does-this-replace-client-state5GV28资讯网——每日最新资讯28at.com

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

趋势

在 react 中使用 swr、react-query 是大势所趋,可以从 npm 下载量来看出来。相信今后在 vue 中 vue-query 也会有越来越多的使用,因为另外三大框架都是跟随 react 走的 hooks 的思想。5GV28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-80841-0.htmlVue3 中有些场景,真不想用 Pinia !

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: .NET中异步操作的选择:Task vs. ValueTask的区别与性能优化

下一篇: 小小ArrayList,居然这么多坑?!

标签:
  • 热门焦点
  • Golang 中的 io 包详解:组合接口

    io.ReadWriter// ReadWriter is the interface that groups the basic Read and Write methods.type ReadWriter interface { Reader Writer}是对Reader和Writer接口的组合,
  • K8S | Service服务发现

    一、背景在微服务架构中,这里以开发环境「Dev」为基础来描述,在K8S集群中通常会开放:路由网关、注册中心、配置中心等相关服务,可以被集群外部访问;图片对于测试「Tes」环境或者
  • 使用LLM插件从命令行访问Llama 2

    最近的一个大新闻是Meta AI推出了新的开源授权的大型语言模型Llama 2。这是一项非常重要的进展:Llama 2可免费用于研究和商业用途。(几小时前,swyy发现它已从LLaMA 2更名为Lla
  • 每天一道面试题-CPU伪共享

    前言:了不起:又到了每天一到面试题的时候了!学弟,最近学习的怎么样啊 了不起学弟:最近学习的还不错,每天都在学习,每天都在进步! 了不起:那你最近学习的什么呢? 了不起学弟:最近在学习C
  • 电视息屏休眠仍有网络上传 爱奇艺被质疑“薅消费者羊毛”

    记者丨宁晓敏 见习生丨汗青出品丨鳌头财经(theSankei) 前不久,爱奇艺发布了一份亮眼的一季报,不仅营收和会员营收创造历史最佳表现,其运营利润也连续6个月实现增长。自去年年初
  • 猿辅导与新东方的两种“归途”

    作者|卓心月 出品|零态LT(ID:LingTai_LT)如何成为一家伟大企业?答案一定是对“势”的把握,这其中最关键的当属对企业战略的制定,且能够站在未来看现在,即使这其中的
  • 联想小新Pad Pro 12.6将要推出,搭载高通骁龙 870 处理器

    联想小新Pad Pro 12.6将于秋季新品会上推出,官方按照惯例直接在发布会前给出了机型的所有参数。联想小新 Pad Pro 12.6 将搭载高通骁龙 870 处理器,重量为 5
  • 与兆芯合作 联想推出全新旗舰版笔记本电脑开天N7系列

    联想与兆芯合作推出全新联想旗舰版笔记本电脑开天 N7系列。这个系列采用兆芯KX-6640MA处理器平台,KX-6640MA 处理器是采用了陆家嘴架构,16nm 工艺,4 核 4 线
  • “买真退假” 这种“羊毛”不能薅

    □ 法治日报 记者 王春   □ 本报通讯员 胡佳丽  2020年初,还在上大学的小东加入了一个大学生兼职QQ群。群主“七王”在群里介绍一些刷单赚
Top