分享一个后端说异步导出,前端的实现方法

最近做项目遇到一个导出报表的功能,后端说是异步的,前端如何处理呢?话不多说直接上方案

在页面中做一个进度条弹窗

html 复制代码
<el-dialog : visivle.sync="showProgress" width="30%" :show-close="false" :close-on-click-modal="false">
    <p>正在导出,请稍后...</p>
    <el-progress :text-inside="true" :percentage="percentageVal" color="rgba(142,113,199,0.7)"></el-progress>
</el-dialog>

在导出按钮点击时,将showProress置为true,将percentageVal置为0,然后开始调用一个异步的后端接口,在接口内部传了个type类型表示是哪个报表,之后拿到res之后,res会给返回一个标识,或者是编号之类的,之后前端再调用一个函数来将这个编号传入,

_queryTask()函数主要功能是通过post请求查询任务进度,并根据返回的状态进行响应的处理

请求构建

serialno作为请求参数data中的serialno字段,

使用http的post方法请求/api/progress/XX接口,设置了超时时间为0并且传递了取消令牌this.source = this.http.Canceltoken.source()

返回处理

如果返回的code为'0',表示请求成功,进一步处理结果

let result = res.data.data

如果uploadStatus为'0',表示上传中,更新进度值percentageVal为uploadProgress,并使用setTimeout实现递归查询任务状态

如果uploadStatus为'1',表示上传成功,将进度值设为100,取消查询任务(this.source.cancel()),跳转到文件下载页面(window.location.href = `{filApi}/api/file/down/?id={id}&timestap=XX`),并显示成功消息

如果uploadStatus为'2',并且有uploadMessage,表示上传失败,取消查询任务,关闭进度条,显示失败信息

如果返回的code值不为'0',显示错误消息

相关推荐
秋天的一阵风24 分钟前
GeekGeekRun:求职路上的开源神器🚀🚀🚀
前端·面试·求职
yinuo26 分钟前
实现二维码扫码器动画效果
前端
八岁小孩学编程42 分钟前
Figma多语言JSON的解决方案:手把手打造React Figma AI Chrome扩展
前端·react.js·ai编程
pe7er1 小时前
使用 force-resolutions 强制锁定 npm/yarn 依赖版本
前端·javascript
JinSo1 小时前
EasyDashboard 数据源功能来啦!
前端·javascript·github
Mike_jia1 小时前
Netdata:实时监控领域的“超音速战机”——从零构建企业级运维观测体系
前端
Mike_jia1 小时前
RustDesk:开源远程桌面的颠覆者——从极简部署到企业级实战全解析
前端
晓得迷路了1 小时前
栗子前端技术周刊第 86 期 - React Native 0.80、Bun v1.2.16、Astro 5.10...
前端·javascript·bun
JustHappy1 小时前
「web前端性能优化慢聊🚀」从域名到IP,咱切图仔可以做啥?—— DNS解析优化慢聊
前端
心.c1 小时前
React基础
前端·javascript·react.js