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

React 中如何展示 XHR 和 Fetch 的请求响应进度?

来源: 责编: 时间:2024-07-15 17:18:53 245观看
导读响应进度前段时间做了一个需求,需要将请求响应的进度展示给用户看,就比如下面这样的效果。响应进度从 0% 到 100% ,去展示给用户观看。图片其实动画效果倒是不难,可以直接用 ant-design 的 Progress 组件去展示进度。真正

响应进度

前段时间做了一个需求,需要将请求响应的进度展示给用户看,就比如下面这样的效果。x6S28资讯网——每日最新资讯28at.com

响应进度从 0% 到 100% ,去展示给用户观看。x6S28资讯网——每日最新资讯28at.com

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

x6S28资讯网——每日最新资讯28at.com

其实动画效果倒是不难,可以直接用 ant-design 的 Progress 组件去展示进度。x6S28资讯网——每日最新资讯28at.com

真正的难点在于:如何实时获取请求响应的进度?x6S28资讯网——每日最新资讯28at.com

如何实时获取请求响应的进度?

其实这个问题最近几年很多人都反馈说面试中被问到,并且面试官会问你 Xhr 和 Fetch 这两种请求方式,他们各自的响应进度应该怎么获取~x6S28资讯网——每日最新资讯28at.com

Xhr(XMLHttpRequest)

Xhr 的响应进度其实是比较好获取的,因为 JavaScript 官方提供了一个监听函数 progress来对响应进度进行监听。x6S28资讯网——每日最新资讯28at.com

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

x6S28资讯网——每日最新资讯28at.com

并且这个方法接收一个对象,对象中有两个属性很重要:x6S28资讯网——每日最新资讯28at.com

  • total: 总响应数据的长度
  • loaded: 已加载的响应数据的长度

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

x6S28资讯网——每日最新资讯28at.com

所以我们可以根据这两个字段来算出百分比,进而展示出来!x6S28资讯网——每日最新资讯28at.com

在此之间我先自己用 express 在本地起了一个本地服务,用来演示发起请求。x6S28资讯网——每日最新资讯28at.com

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

x6S28资讯网——每日最新资讯28at.com

接着回到前端页面,我们使用组件库,写出一个页面!x6S28资讯网——每日最新资讯28at.com

x6S28资讯网——每日最新资讯28at.com

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

x6S28资讯网——每日最新资讯28at.com

x6S28资讯网——每日最新资讯28at.com

当我们点击按钮发起请求并收到响应后,会监听到每次的百分比。x6S28资讯网——每日最新资讯28at.com

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

x6S28资讯网——每日最新资讯28at.com

有了百分比,我们只需要把百分比放到 Progress 组件中即可实现展示效果:x6S28资讯网——每日最新资讯28at.com

x6S28资讯网——每日最新资讯28at.com

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

x6S28资讯网——每日最新资讯28at.com

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

x6S28资讯网——每日最新资讯28at.com

Fetch

其实 Fetch 也是同理,只要我们能拿到 total 和 loaded ,也就是 数据总长度 和 已加载长度,就能算出百分比。x6S28资讯网——每日最新资讯28at.com

但是 Fetch 没有监听函数,所以得换一种方式去获取,大概思路就是:x6S28资讯网——每日最新资讯28at.com

  • 先从请求头获取到 content-length 总长度。
  • 再用数据流的 API body.getReader 去读取响应体当前已加载的长度。

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

x6S28资讯网——每日最新资讯28at.com

x6S28资讯网——每日最新资讯28at.com

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

x6S28资讯网——每日最新资讯28at.com

x6S28资讯网——每日最新资讯28at.com

最终也能达到我们想要的结果。x6S28资讯网——每日最新资讯28at.com

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

x6S28资讯网——每日最新资讯28at.com

上传进度

说完响应进度,我们再来说说上传进度应该怎么去监听呢?x6S28资讯网——每日最新资讯28at.com

XHR

XHR 可以使用XMLHttpRequest.upload自带的监听函数progress去做。x6S28资讯网——每日最新资讯28at.com

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

x6S28资讯网——每日最新资讯28at.com

x6S28资讯网——每日最新资讯28at.com

x6S28资讯网——每日最新资讯28at.com

x6S28资讯网——每日最新资讯28at.com

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

本文链接:http://www.28at.com/showinfo-26-100995-0.htmlReact 中如何展示 XHR 和 Fetch 的请求响应进度?

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

上一篇: POST请求为何会发送两次?技术深度解析

下一篇: 智启万象|2024 Google 谷歌开发者大会邀你报名「畅享家」

标签:
  • 热门焦点
  • Redmi Pad评测:红米充满野心的一次尝试

    从Note系列到K系列,从蓝牙耳机到笔记本电脑,红米不知不觉之间也已经形成了自己颇有竞争力的产品体系,在中端和次旗舰市场上甚至要比小米新机的表现来得更好,正所谓“大丈夫生居
  • 5月iOS设备性能榜:M1 M2依旧是榜单前五

    和上个月一样,没有新品发布的iOS设备性能榜的上榜设备并没有什么更替,仅仅只有跑分变化而产生的排名变动,刚刚开始的苹果WWDC2023,推出的产品也依旧是新款Mac Pro、新款Mac Stu
  • K6:面向开发人员的现代负载测试工具

    K6 是一个开源负载测试工具,可以轻松编写、运行和分析性能测试。它建立在 Go 和 JavaScript 之上,它被设计为功能强大、可扩展且易于使用。k6 可用于测试各种应用程序,包括 Web
  • Temu起诉SHEIN,跨境电商战事升级

    来源 | 伯虎财经(bohuFN)作者 | 陈平安日前据外媒报道,拼多多旗下跨境电商平台Temu正对竞争对手SHEIN提起新诉讼,诉状称Shein“利用市场支配力量强迫服装厂商与之签订独家
  • 腾讯盖楼,字节拆墙

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之“想重温暴刷深渊、30+技能搭配暴搓到爽的游戏体验吗?一起上晶核,即刻暴打!”曾凭借直播腾讯旗下代理格斗游戏《DNF》一
  • 当家的盒马,加速谋生

    来源 | 价值星球Planet作者 | 归去来自己“当家”的盒马,开始加速谋生了。据盒马官微消息,盒马计划今年开放生鲜供应链,将其生鲜商品送往食堂。目前,盒马在上海已经与
  • 消息称小米汽车开始筛选交付中心:需至少120个车位

    IT之家 7 月 7 日消息,日前,有微博简介为“汽车行业从业者、长三角一体化拥护者”的微博用户 @长三角行健者 发文表示,据经销商集团反馈,小米汽车目前
  • 2299元起!iQOO Pad开启预售:性能最强天玑平板

    5月23日,iQOO如期举行了新品发布会,除了首发安卓最强旗舰处理器的iQOO Neo8系列新机外,还在发布会上推出了旗下首款平板电脑——iQOO Pad,其搭载了天玑
  • 首发天玑9200+ iQOO Neo8系列发布首销售价2299元起

    2023年5月23日晚,iQOO Neo8系列正式发布。其中,Neo系列首款Pro之作——iQOO Neo8 Pro强悍登场,限时售价3099元起;价位段最强性能手机iQOO Neo8同期上市
Top