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

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

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

响应进度

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

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

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

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

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

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

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

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

Xhr(XMLHttpRequest)

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Fetch

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

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

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

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

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

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

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

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

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

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

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

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

上传进度

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

XHR

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

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

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

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

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

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

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

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

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

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

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

标签:
  • 热门焦点
  • K60至尊版刚预热 一加Ace2 Pro正面硬刚

    K60至尊版刚预热 一加Ace2 Pro正面硬刚

    Redmi这边刚如火如荼的宣传了K60 Ultra的各种技术和硬件配置,作为竞品的一加也坐不住了。一加中国区总裁李杰发布了两条微博,表示在自家的一加Ace2上早就已经采用了和PixelWo
  • 5月安卓手机好评榜:魅族20 Pro夺冠

    5月安卓手机好评榜:魅族20 Pro夺冠

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年5月1日至5月31日,仅限国内市场。第一名:魅族20 Pro好评率:97.50%不得不感慨魅族老品牌还
  • 一篇聊聊Go错误封装机制

    一篇聊聊Go错误封装机制

    %w 是用于错误包装(Error Wrapping)的格式化动词。它是用于 fmt.Errorf 和 fmt.Sprintf 函数中的一个特殊格式化动词,用于将一个错误(或其他可打印的值)包装在一个新的错误中。使
  • 学习JavaScript的10个理由...

    学习JavaScript的10个理由...

    作者 | Simplilearn编译 | 王瑞平当你决心学习一门语言的时候,很难选择到底应该学习哪一门,常用的语言有Python、Java、JavaScript、C/CPP、PHP、Swift、C#、Ruby、Objective-
  • 一篇文章带你了解 CSS 属性选择器

    一篇文章带你了解 CSS 属性选择器

    属性选择器对带有指定属性的 HTML 元素设置样式。可以为拥有指定属性的 HTML 元素设置样式,而不仅限于 class 和 id 属性。一、了解属性选择器CSS属性选择器提供了一种简单而
  •  三星推出Galaxy Tab S9系列平板电脑以及Galaxy Watch6系列智能手表

    三星推出Galaxy Tab S9系列平板电脑以及Galaxy Watch6系列智能手表

    2023年7月26日,三星电子正式发布了Galaxy Z Flip5与Galaxy Z Fold5。除此之外,Galaxy Tab S9系列平板电脑以及三星Galaxy Watch6系列智能手表也同期
  • 三星显示已开始为AR设备研发硅基LED微显示屏

    三星显示已开始为AR设备研发硅基LED微显示屏

    7月18日消息,据外媒报道,随着苹果首款头显产品Vision Pro在6月份正式推出,AR/VR/MR等头显产品也就将成为各大公司下一个重要的竞争领域,对显示屏这一关
  • iQOO 11S评测:行业唯一的200W标准版旗舰

    iQOO 11S评测:行业唯一的200W标准版旗舰

    【Techweb评测】去年底,iQOO推出了“电竞旗舰”iQOO 11系列,作为一款性能强机,该机不仅全球首发2K 144Hz E6全感屏,搭载了第二代骁龙8平台及144Hz电竞
  • 质感不错!OPPO K11渲染图曝光:旗舰IMX890传感器首次下放

    质感不错!OPPO K11渲染图曝光:旗舰IMX890传感器首次下放

    一直以来,OPPO K系列机型都保持着较为均衡的产品体验,历来都是2K价位的明星机型,去年推出的OPPO K10和OPPO K10 Pro两款机型凭借各自的出色配置,堪称有
Top
Baidu
map