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

如何获取请求的进度,并展示给用户看?

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

响应进度

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

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

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


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

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

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

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

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

Xhr(XMLHttpRequest)

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

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

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

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

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

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

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

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

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

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

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

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


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

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

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

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


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

Fetch

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

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

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

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

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

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

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


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

上传进度

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

XHR

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

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

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

Fetch

目前还未有办法可以监听,小伙伴们如果有方案的话,可以分享出来!pyI28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-97281-0.html如何获取请求的进度,并展示给用户看?

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

上一篇: 性能指标 | CPU飙高排查实战

下一篇: ECMAScript 2024 正式发布,新特性一览!

标签:
  • 热门焦点
  • 一加Ace2 Pro真机揭晓 钛空灰配色质感拉满

    终于,在经过了几波预热之后,一加Ace2 Pro的外观真机图在网上出现了。还是博主数码闲聊站曝光的,这次的外观设计还是延续了一加11的方案,只是细节上有了调整,例如新加入了钛空灰
  • 线程通讯的三种方法!通俗易懂

    线程通信是指多个线程之间通过某种机制进行协调和交互,例如,线程等待和通知机制就是线程通讯的主要手段之一。 在 Java 中,线程等待和通知的实现手段有以下几种方式:Object 类下
  • 如何正确使用:Has和:Nth-Last-Child

    我们可以用CSS检查,以了解一组元素的数量是否小于或等于一个数字。例如,一个拥有三个或更多子项的grid。你可能会想,为什么需要这样做呢?在某些情况下,一个组件或一个布局可能会
  • 2023年,我眼中的字节跳动

    此时此刻(2023年7月),字节跳动从未上市,也从未公布过任何官方的上市计划;但是这并不妨碍它成为中国最受关注的互联网公司之一。从2016-17年的抖音强势崛起,到2018年的“头腾
  • Temu起诉SHEIN,跨境电商战事升级

    来源 | 伯虎财经(bohuFN)作者 | 陈平安日前据外媒报道,拼多多旗下跨境电商平台Temu正对竞争对手SHEIN提起新诉讼,诉状称Shein“利用市场支配力量强迫服装厂商与之签订独家
  • 腾讯VS网易,最卷游戏暑期档,谁能笑到最后?

    作者:无锈钵来源:财经无忌7月16日晚,上海1862时尚艺术中心。伴随着幻象的精准命中,硕大的荧幕之上,比分被定格在了14:12,被寄予厚望的EDG战队以绝对的优势战胜了BLG战队,拿下了总决
  • 三星折叠屏手机去年销售近1000万台 今年目标定为1500万

    7月29日消息,三星率先发力可折叠手机市场,在全球市场已经取得了非常亮眼的成绩,接下来会进一步巩固和扩大这一优势。三星在推出Galaxy Z Flip5和Galax
  • OPPO Reno10 Pro英雄联盟定制礼盒公布:萨勒芬妮同款配色梦幻十足

    5月24日,OPPO推出了全新的OPPO Reno 10系列,包含OPPO Reno10、OPPO Reno10 Pro和OPPO Reno10 Pro+三款新机,全系标配了超光影长焦镜头,是迄今为止拍照
  • 三翼鸟智能家居亮相电博会,让用户体验更真实

    2021电博会在青岛国际会展中心开幕中,三翼鸟直接把“家”搬到了现场,成为了展会的一大看点。这也是三翼鸟继9月9日发布了行业首个一站式定制智慧家平台后的
Top