关于文件下载的那点事

后端返回Blob形式的文件流  前端接受文件流  并下载

前端需要做多浏览器的兼容

if(response.headers['content-type'] == 'application/vnd.ms-excel;charset=utf-8'){
    let type = response.headers['content-type'];
    let fileName = decodeURI(response.headers['content-disposition'] + '').replace('attachment;filename=', '');
    var blob = new Blob([response.data], {type: 'application/vnd.ms-excel;charset=utf-8'})
    if (typeof window.navigator.msSaveBlob !== 'undefined') {
      window.navigator.msSaveBlob(blob, fileName)
    } else {
      let URL = window.URL || window.webkitURL
      let objectUrl = URL.createObjectURL(blob)
      if (fileName) {
        var a = document.createElement('a')
        if (typeof a.download === 'undefined') {
          window.location = objectUrl
        } else {
          a.href = objectUrl
          a.download = fileName
          document.body.appendChild(a)
          a.click()
          a.remove()
        }
      } else {
        window.location = objectUrl
      }
      URL.revokeObjectURL(objectUrl)
    }
  }

注意:请求的时候 responseType 要进行设置

responseType:'arraybuffer'

 

你可能感兴趣的:(JS)