您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

如何在vue.js中使用axios实现下载功能

2024/3/9 2:25:27发布25次查看
这次给大家带来如何在vue.js中使用axios实现下载功能,在vue.js中使用axios实现下载功能的注意事项有哪些,下面就是实战案例,一起来看一下。
本文主要来源于知乎一个回答,这里红色部分做了自己的处理,虽然自己的少,可是很有用的几句代码哦
只好回答一下axios如何拦截get请求并下载文件的了。
ajax无法下载文件的原因
浏览器的get(frame、a)和post(form)请求具有如下特点:
response会交由浏览器处理
response内容可以为二进制文件、字符串等
ajax请求具有如下特点:
response会交由javascript处理
response内容仅可以为字符串
因此,ajax本身无法触发浏览器的下载功能。
axios拦截请求并实现下载
为了下载文件,我们通常会采用以下步骤:
发送请求
获得response
通过response判断返回是否为文件
如果是文件则在页面中插入frame
利用frame实现浏览器的get下载
我们可以为axios添加一个拦截器:
import axios from 'axios' // download url const downloadurl = url => {  let iframe = document.createelement('iframe')  iframe.style.display = 'none'  iframe.src = url  iframe.onload = function () {  document.body.removechild(iframe)  }  document.body.appendchild(iframe) } // add a response interceptor axios.interceptors.response.use(c=> {  // 处理excel文件  if (res.headers && (res.headers['content-type'] === 'application/x-msdownload' || res.headers['content-type'] === 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet')) {  downloadurl(res.request.responseurl)    <span style="color:#ff0000;"> res.data='';  res.headers['content-type'] = 'text/json'  return res;</span>  }  ...  return res; }, error => {  <span style="color:#ff0000;">// do something with response error  return promise.reject(error.response.data || error.message)</span> }) export default axios
之后我们就可以通过axios中的get请求下载文件了。
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
vue项目怎样通过百度的bae发布
vue中引入highcharts的图文详解
以上就是如何在vue.js中使用axios实现下载功能的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product