为了账号安全,请及时绑定邮箱和手机立即绑定

VUE 表单下载(自定义下载文件名)

环境:项目通过VUE CLI3 搭建。请求为axios

在本地的文件下载:

  1. 将文件传至工程中默认的 public 文件夹中

  2. <a class="btn-link" 
      href="/file/文件名.xlsx"
      download="自定义文件名.xlsx">
      点击下载
    </a>

请求后端,转换后台你返回的二进制流:

HTML:

<button @click="download(/*参数1*/,/*参数2*/)">点击下载</button>

JS:

download (/*参数1*/,/*参数2*/) {
  let params = {
    'id':/*参数1*/,
    'fileName': /*参数2*/
  }
  axios.post(/*请求后台地址*/, null, {
      responseType: 'blob',//声明后端返回的数据为二进制流
        transformRequest: [() => {
      let formData = new FormData()
      formData.append('params', JSON.stringify(params))
      return formData
    }]
  }).then(res => {
    //将二进制流转化为链接
    let blob = new Blob([res], { type: 'application/vnd.ms-excel' })
    let downloadElement = document.createElement('a')
    let href = URL.createObjectURL(blob)
    downloadElement.href = href
    downloadElement.download = /*自定义文件名*/
    document.body.appendChild(downloadElement)
    downloadElement.click()
    document.body.removeChild(downloadElement)
    window.URL.revokeObjectURL(href)
  })
},


点击查看更多内容
1人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消