当前位置: 首页 > news >正文

axios 下载大文件时,展示下载进度的组件封装——js技能提升

之前面试的时候,有遇到一个问题:就是下载大文件的时候,如何得知下载进度,当时的回复是没有处理过。。。

现在想到了。axios中本身就有一个下载进度的方法,可以直接拿来使用。

下面记录一下处理步骤:

参考链接:https://blog.csdn.net/yyh123456hhh/article/details/131637151

解决步骤1:给封装好的axios方法中添加onDownloadProgress

这个方法就是监听接口进度的方法了,可以作为入参进行处理。

解决步骤2:在使用request时,写入onDownloadProgress

export async function exportPageList(params, config, downloadProgress) {return request(`/api/quality-service/FeedReasons/export-feedreason-datas`,METHOD.GET,params,config,//请求头或者文档格式设置等downloadProgress//接口请求进度);
}

解决步骤3:具体使用方法

html部分:

<a-modaltitle="导出":footer="null":visible="visible":width="500":closable="false"><div class="download-progress"><a-progress :percent="percent" /><p>正在导出...</p></div>
</a-modal>

需要传入的参数:visible percent
是否展示弹窗和进度条占比

exportPageList(params,{responseType: 'blob'},(progress) => {this.visible = true;this.percent = (progress.loaded / progress.total) * 100;if (this.percent >= 100) {setTimeout(() => {this.visible = false;}, 200);}}
)
.then((res) => {let blobUrl = window.URL.createObjectURL(res);let link = document.createElement('a');link.style.display = 'none';link.download = `报废原因配置_${moment().format('YYYY/MM/DD')}.xlsx`;link.href = blobUrl;document.body.appendChild(link);link.click();document.body.removeChild(link);
})
.finally(() => {this.spinning = false;
});

最终效果如下:
在这里插入图片描述

http://www.lryc.cn/news/402259.html

相关文章:

  • Linux: network: device事件注册机制 chatGPT; notify
  • 【ROS2】测试
  • 别卷模型,卷应用:从李彦宏的AI观点谈起
  • 数据库(Database,简称DB)介绍
  • Redis五种常用数据类型详解及使用场景
  • Postman API测试覆盖率:全面评估指南
  • C++--find
  • JavaWeb入门程序解析(Spring官方骨架、配置起步依赖、SpringBoot父工程、内嵌Tomcat)
  • mysql命令练习
  • AI绘画Stable Diffusion 零基础入门 —AI 绘画原理与工具介绍,万字解析AI绘画的使用教程
  • jenkins添加ssh证书
  • C++--accumulate介绍
  • C++写一个线程池
  • 【SASS/SCSS(一)】选择器
  • 详细解析Kafaka Streams中各个DSL操作符的用法
  • C++中链表的底层迭代器实现
  • 3.5、matlab打开显示保存点云文件(.ply/.pcd)以及经典点云模型数据
  • Qt-事件与信号
  • 数据结构 day3
  • Kubernetes面试整理-如何进行滚动更新和回滚?
  • flutter ios打包 xcode报错module ‘xxx‘ not found
  • LLM 构建Data Multi-Agents 赋能数据分析平台的实践之④:数据分析之三(数据展示)
  • Elasticsearch 批量更新
  • 【Pytorch笔记】张量
  • 查找json中指定节点的值,替换为指定的值
  • Android 14 开机时间优化措施
  • 【QGroundControl二次开发】二.使用QT编译QGC(Windows)
  • [C/C++入门][变量和运算]4、带余除法
  • 常用优秀内网穿透工具(实测详细版)
  • 防火墙NAT地址转换和智能选举综合实验