blob形式导出Excel

export function getParticipantList(param) {
    return ecloudRequest({
        url: "",
        method: "get",
        params: param,
        responseType: param.isExport ? 'blob' : ''
    });
}

接口返回处理

const blob = new Blob([res])
            const fileName = ''
            if (navigator.userAgent.indexOf("Trident") !== -1) {
                window.navigator.msSaveOrOpenBlob(blob, fileName)
            } else {
                const a = document.createElement("a")
                a.href = URL.createObjectURL(blob)
                a.download = fileName
                a.innerHTML = "导出"
                a.style.display = "none"
                document.body.appendChild(a) // 防止firefox无法触发click
                a.click()
                setTimeout(() => {
                    document.body.removeChild(a)
                }, 10000)
            }

解决火狐浏览器中下载格式xml的问题,加type,后缀

export function fileDownload(id, fileName,suffix) {
    downloadFileById(id).then(res => {
        if(navigator.userAgent.indexOf("Trident") !== -1) {
            window.navigator.msSaveOrOpenBlob(new Blob([res]),fileName,suffix)
        }else {
            let link = document.createElement("a");
            if(suffix) {
                link.href = window.URL.createObjectURL(new Blob([res],{type:"text/"+suffix}));
            }else {
                link.href = window.URL.createObjectURL(new Blob([res]));
            }
            link.target = "_blank";
            link.download = fileName;
            document.body.appendChild(link); // Firefox 中必须这么写,不然不会起效果
            link.click();
            document.body.removeChild(link);
        }  
    });
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,我会回答你的问题。但是需要说明的是,我并不是一个能够直接读取数据库中的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浏览器进行特殊处理。 希望这个示例代码能够帮助你完成你的需求。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值