Vue通过Blob对象实现导出Excel功能(2种方法)

方法一:Excel 在 前端命名

 通过请求接口,发送请求。 基本像下面这个就可以导出实现了

exportExcel() {
      this.$axios({
        method: "",
        url: "XXXXX",
        data: {},
        //下面这二个必须带上
        headers: {
          'Content-Type': "application/json;charset=UTF-8"
        },
        responseType: "blob"

      }).then(res => {
        console.log(res,'res')
        const blob = new Blob([res.data]);
        let url = window.URL.createObjectURL(blob);
        const link = document.createElement("a");
        link.href = url;
        link.download = "填报情况统计列表" + this.timeFilter() + ".xlsx"; //命名Excel名字
        link.click();
        URL.revokeObjectURL(url);
      }).catch((err) => {
        this.$message({
          message: err.message,
          type: 'error',
        })
      })
    },

方法二:

        只导出当前所显示结果页面的表格进入excel,就用插件,比如vue-json-excel或者是Blob.js+Export2Excel.js来实现导出Excel功能。

        但是有些需求因为数据量太大,成千上万条数据,所以是需要后端拼接,然后输出二进制流文件,然后前端直接下载,这次我们谈谈后者的做法。

exportExcel() {
      var params = {
        XX: xx//需要携带的请求体            
      }
      this.$axios.get('/XX/XX', {
        params: params,
        responseType: 'blob'//首先设置responseType字段格式为 blob
      }).then(res => {
        console.log(res);
        let blob = new Blob([res], { type: "application/vnd.ms-excel" });// 为blob设置文件类型,这里以.xlsx为例
        let url = window.URL.createObjectURL(blob); // 创建一个临时的url指向blob对象
        let a = document.createElement("a");
        a.href = url;
        a.click();// 释放这个临时的对象url                
        window.URL.revokeObjectURL(url); 
      });
    },

'responseType'表示的是服务器响应的数据类型,可以是'arrayBuffer'、'blob'、'document'、'json'、'txt'、'stream',默认为json。axios官方文档地址: https://www.kancloud.cn/yunye/axios/234845(axios请求配置章节)。

所以我们接收后台传给前端的二进制流之前需要先设置responseType为blob,否则默认会以json获取,下载下来的文件打开会提示文件已损坏。控制台输出的可以看到是个正确的Blob对象,这就说明我们的配置是对的。

后端最好也要配置response头的content-type为对应的类型

 

然后,需要给这个Blob对象设置一个type,这个type表明改Blob对象所包含数据的MIME类型。如果类型未知,则该值为空字符串。这里给出几个常用文件格式的MIME类型:(详细的可参考WebAPI官方文档: https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Basics_of_HTTP/MIME_types/Common_types

       扩展名----------MIME类型

  .csv--------------text/csv

  .jpeg/.jpg-------image/jpeg

  .png-------------image/png

  .rar--------------application/x-rar-compressed

  .doc-------------application/msword

  .docx-----------application/vnd.openxmlformats-officedocument.wordprocessingml.document

  .xls--------------application/vnd.ms-excel

       .xlsx------------application/vnd.openxmlformats-officedocument.spreadsheetml.sheet

  .zip--------------application/zip

 一般来说,这样就可以实现下载的功能了。

 

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会回答你的问题。但是需要说明的是,我并不是一个能够直接读取数据库中的blob数据并生成excel文件的程序。我是一个文字AI助手,只能够提供一些相关的代码示例和思路,帮助你完成这个功能。 首先,读取数据库中的blob数据并生成excel文件需要以下几个步骤: 1. 连接数据库,并查询出需要的blob数据。可以使用JDBC或者其他ORM框架来完成这个步骤。 2. 将blob数据转换为excel文件。可以使用Apache POI或者其他的excel操作库来完成这个步骤。具体的方法是:先将blob数据读入到一个InputStream中,然后将这个InputStream作为参数传递给excel操作库的相关方法,即可完成转换。 3. 将生成的excel文件输出到客户端。可以使用Servlet或者其他的web框架来完成这个步骤。具体的方法是:先创建一个输出流,然后将生成的excel文件写入到这个输出流中,最后将这个输出流输出到客户端即可。 下面是一个Vue前端通过Blob对象实现导出Excel功能的示例代码: ``` <template> <div> <button @click="exportExcel">导出Excel</button> </div> </template> <script> import axios from 'axios' export default { methods: { async exportExcel() { const response = await axios.get('/api/exportExcel', { responseType: 'blob' }) const blob = new Blob([response.data], { type: 'application/vnd.ms-excel' }) const url = window.URL.createObjectURL(blob) const link = document.createElement('a') link.href = url link.download = 'example.xlsx' link.click() window.URL.revokeObjectURL(url) } } } </script> ``` 这个示例代码中,通过axios库向后端发送一个导出Excel的请求,后端将生成的excel文件作为blob数据返回。前端通过将这个blob数据转换为URL,然后创建一个a标签,将这个URL赋值给a标签的href属性,再将a标签的download属性设置为excel文件的文件名,最后通过模拟点击a标签来完成excel文件的下载。需要注意的是,这个示例代码中的下载方式不适用于IE浏览器,需要针对IE浏览器进行特殊处理。 希望这个示例代码能够帮助你完成你的需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值