vue导出数据为文件excel,后端返回的是文件流

导出数据记录为excel:

问题:导出数据记录为excel。后端返回的是文件流,前端接受之后,点击导出可下载到本地为excel文件,可打开。


解决方案:

解决:1.前端在请求的时候,接受文件格式设置为:application/octet-stream在这里插入图片描述
2.请求接口设置接受的数据格式为blob
在这里插入图片描述
3.在点击导出按钮的时候请求接口

方式一:
exportData() {
      const that = this
      this.$confirm({
        title: '确定要导出数据吗?',
        content: '此操作将导出所有的入库记录数据',
        onOk() {
          exportInStock({}).then((res) => {
            // console.log(res)
            let blob = new Blob([res], { type: 'application/vnd.ms-excel' }) // res就是接口返回的文件流了
            let objectUrl = URL.createObjectURL(blob)
            window.location.href = objectUrl
        },
        onCancel() {},
        class: 'test',
      })
    },

方式二:在请求到数据之后,写法不同。
            // let fileData = res
            // const url = window.URL.createObjectURL(
            //   new Blob([fileData], {
            //     type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8',
            //   })
            // )
            // const link = document.createElement('a')
            // link.href = url
            // link.setAttribute('download', '文件') // 下载文件的名称及文件类型后缀
            // document.body.appendChild(link)
            // link.click()
            // document.body.removeChild(link) // 下载完成移除元素
            // window.URL.revokeObjectURL(url) // 释放掉blob对象

参考blob文档下载链接:blob type类型介绍

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,可以看出在Vue中实现导出Excel文件后端操作是通过发送请求获取文件,并将文件转换为可下载的链接。具体实现步骤如下: 1. 在后端定义一个接口,用于导出Excel文件。在该接口中,设置响应类型为`application/vnd.ms-excel`,确保返回的是Excel文件格式。同时,将文件作为响应返回前端。 2. 在前端Vue组件中,定义一个导出Excel的方法,例如`exportExcelFn()`。在该方法中,调用后端接口获取文件,并将文件转换为可下载的链接。 3. 在前端Vue组件中,使用`<el-button>`标签绑定导出Excel的方法,例如`<el-button @click="exportExcelFn">导出Excel表格</el-button>`。 4. 在导出Excel的方法中,使用`URL.createObjectURL()`方法将文件转换为可下载的链接,并设置下载的文件名。 5. 创建一个`<a>`标签,将可下载的链接赋值给`href`属性,并设置`download`属性为要下载的文件名。 6. 将`<a>`标签添加到页面的`<body>`元素中,并模拟点击该链接,实现文件的下载。 综上所述,Vue导出Excel文件后端操作可以通过以上步骤实现。 #### 引用[.reference_title] - *1* [前端导出excel文件 vue导出文件后端导出excel文件](https://blog.csdn.net/robotkirin/article/details/122243655)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Vue实现excel文件导出功能(后端直接返回文件)](https://blog.csdn.net/qq_41954585/article/details/124961373)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值