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

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

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

响应进度

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

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

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


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

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

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

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

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

Xhr(XMLHttpRequest)

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

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

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

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

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

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

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

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

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

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

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

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


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

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

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

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


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

Fetch

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

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

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

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

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

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

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


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

上传进度

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

XHR

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

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

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

Fetch

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

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

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

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

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

标签:
  • 热门焦点
  • 对标苹果的灵动岛 华为带来实况窗功能

    继苹果的灵动岛之后,华为也在今天正式推出了“实况窗”功能。据今天鸿蒙OS 4.0的现场演示显示,华为的实况窗可以更高效的展现出实时通知,比如锁屏上就能看到外卖、打车、银行
  • 影音体验是真的强 简单聊聊iQOO Pad

    大公司的好处就是产品线丰富,非常细分化的东西也能给你做出来,例如早先我们看到了新的vivo Pad2,之后我们又在iQOO Neo8 Pro的发布会上看到了iQOO的首款平板产品iQOO Pad。虽
  • Raft算法:保障分布式系统共识的稳健之道

    1. 什么是Raft算法?Raft 是英文”Reliable、Replicated、Redundant、And Fault-Tolerant”(“可靠、可复制、可冗余、可容错”)的首字母缩写。Raft算法是一种用于在分布式系统
  • 28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈

    前言在使用SpringBoot开发中或者在求职面试中都会使用到很多注解或者问到注解相关的知识。本文主要对一些常用的注解进行了总结,同时也会举出具体例子,供大家学习和参考。注解
  • 使用AIGC工具提升安全工作效率

    在日常工作中,安全人员可能会涉及各种各样的安全任务,包括但不限于:开发某些安全工具的插件,满足自己特定的安全需求;自定义github搜索工具,快速查找所需的安全资料、漏洞poc、exp
  • 梁柱接棒两年,腾讯音乐闯出新路子

    文丨田静 出品丨牛刀财经(niudaocaijing)7月5日,企鹅FM发布官方公告称由于业务调整,将于9月6日正式停止运营,这意味着腾讯音乐长音频业务走向消亡。腾讯在长音频领域还在摸索。为
  • 微博大门常打开,迎接海外画师漂洋东渡

    作者:互联网那些事“起猛了,我能看得懂日语了”。“为什么日本人说话我能听懂?”“中文不像中文,日语不像日语,但是我竟然看懂了”…&hell
  • 三星显示已开始为AR设备研发硅基LED微显示屏

    7月18日消息,据外媒报道,随着苹果首款头显产品Vision Pro在6月份正式推出,AR/VR/MR等头显产品也就将成为各大公司下一个重要的竞争领域,对显示屏这一关
  • 回归OPPO两年,一加赢了销量,输了品牌

    成为OPPO旗下主打性能的先锋品牌后,一加屡创佳绩。今年618期间,一加手机全渠道销量同比增长362%,凭借一加 11、一加 Ace 2、一加 Ace 2V三款爆品,一加
Top