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

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

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

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

背景

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

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

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

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

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

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

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

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

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

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

vue-query

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

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

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

pnpm i vue-query

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

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

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

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

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

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

总结

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

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

趋势

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

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

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

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

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

标签:
  • 热门焦点
  • 6月安卓手机好评榜:魅族20 Pro蝉联冠军

    6月安卓手机好评榜:魅族20 Pro蝉联冠军

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年6月1日至6月30日,仅限国内市场。第一名:魅族20 Pro好评率:95%5月份的时候魅族20 Pro就是
  • 6月安卓手机性价比榜:Note 12 Turbo断层式碾压

    6月安卓手机性价比榜:Note 12 Turbo断层式碾压

    6月份有一个618,虽然这是京东周年庆的日子,但别的电商也都不约而同的跟进了,反正促销没坏处,厂商和用户都能满意。618期间一些产品也出现了历史低价,那么各个价位段的产品性价比
  • 轿车从天而降电动车主被撞身亡 超速抢道所致:现场视频让网友吵翻

    轿车从天而降电动车主被撞身亡 超速抢道所致:现场视频让网友吵翻

    近日,上海青浦区法院判决轿车从天而降电动车主被撞身亡案,轿车车主被判有期徒刑一年。案件显示当时男子驾驶轿车在上海某路段行驶,前车忽然转弯提速超车,
  • Rust中的高吞吐量流处理

    Rust中的高吞吐量流处理

    作者 | Noz编译 | 王瑞平本篇文章主要介绍了Rust中流处理的概念、方法和优化。作者不仅介绍了流处理的基本概念以及Rust中常用的流处理库,还使用这些库实现了一个流处理程序
  • Temu起诉SHEIN,跨境电商战事升级

    Temu起诉SHEIN,跨境电商战事升级

    来源 | 伯虎财经(bohuFN)作者 | 陈平安日前据外媒报道,拼多多旗下跨境电商平台Temu正对竞争对手SHEIN提起新诉讼,诉状称Shein“利用市场支配力量强迫服装厂商与之签订独家
  • 得物宠物生意「狂飙」,发力“它经济”

    得物宠物生意「狂飙」,发力“它经济”

    作者|花花小萌主近日,得物宣布正式上线宠物鉴别,通过得物App内的“在线鉴别”,可找到鉴别宠物的选项。通过上传自家宠物的部位细节,就能收获拥有专业资质认证的得物鉴
  • 腾讯盖楼,字节拆墙

    腾讯盖楼,字节拆墙

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之“想重温暴刷深渊、30+技能搭配暴搓到爽的游戏体验吗?一起上晶核,即刻暴打!”曾凭借直播腾讯旗下代理格斗游戏《DNF》一
  • 签约井川里予、何丹彤,单视频点赞近千万,MCN黑马永恒文希快速崛起!

    签约井川里予、何丹彤,单视频点赞近千万,MCN黑马永恒文希快速崛起!

    来源:视听观察永恒文希传媒作为一家MCN公司,说起它的名字来,可能大家会觉得有点儿陌生,但是说出来下面一串的名字之后,或许大家就会感到震惊,原来这么多网红,都签约这家公司了。根
  • iQOO Neo8系列新品发布会

    iQOO Neo8系列新品发布会

    旗舰双芯 更强更Pro
Top