前端秃头党

axios 设置的responseType 为blob下载文件,

2021-07-08  本文已影响0人  有你有团

使用axios的responseType设置为blob下载文件

// 兼容ie
if(window.naviagtor.msSaveBlob){
  try{
    const blobData = new Blob([res.data])
    window.navigator.msSaveBlob(blobData,'文件名')
  }catch(e){
    console.log('下载文件失败')
  }
}else{
  const url = window.URL.createobjectURL(res.data)
  const link = document.createElement('a')
  link.href = url
  link.download = '文件名'
  link.click()
  URL.revokeobjectURL(url)
}

FileReader

const reader = new FileReader()
reader.onload = (event) => {
  const result = JSON.parse(event.target.result)
  // 此时可以根据后端相应数据进行提示
}

注意点

如果使用 FileReader 将blob转换为必须等待响应体返回 type:'application/json',注意ie浏览器中返回的type类型,带有charset=utf-8 ,可以优先使用type进行判断,如果type 包含application/json,就进行错误处理

完整代码

function downloadFile(id){
  axios.post('/file',{fileId:id}).then(res => {
    if(res.data.type.indexOf('application/json') > -1){
      const reader = new FileReader()
      reader.onload = (event) => {
      const result = JSON.parse(event.target.result)
      // 此时可以根据后端相应数据进行提示
      }
    }else{
      if(window.naviagtor.msSaveBlob){
        try{
          const blobData = new Blob([res.data])
          window.navigator.msSaveBlob(blobData,'文件名')
        }catch(e){
          console.log('下载文件失败')
        }
      }else{
        const url = window.URL.createobjectURL(res.data)
        const link = document.createElement('a')
        link.href = url
        link.download = '文件名'
        link.click()
        URL.revokeobjectURL(url)
      }
    }
  })
}
上一篇 下一篇

猜你喜欢

热点阅读