blob没权限 ie_js使用Blob对象下载兼容ie

官方解释:Blob是一个类文件的不可变的原始数据对象,非javascript原生数据类型,File对象就是继承自Blob对象,且在Blob的基础上进行扩展,以便支持用户系统上的文件。

先贴下载代码

var html =

'

' +document.getElementsByClassName("projectTable")[0].outerHTML +

"";var blob = new Blob([html], { type: "application/vnd.ms-excel"});var a = document.createElement("a");

a.href=URL.createObjectURL(blob);

a.download= "工程统计表.xls";

document.body.appendChild(a);

a.οnclick= function() {

document.body.removeChild(a);

};

a.click();

如果直接使用Blob下载,其他浏览器正常但在ie会出现这样的问题无法正常下载

21f587984886a1710ff5e69abb0738dc.png

百度发现:微软在ie10 和ie11中有两个能解决这个问题的方法:window.navigator.msSaveBlob和window.navigator.msSaveOrOpenBlob 方法,这两个方法的区别在于,The Navigator.msSaveOrOpenBlob() method saves the File or Blob to disk. This method behaves in the same way as Navigator.msSaveBlob() except that this enables the file open option.(前者只有保存,后者有保存和打开两个选项)

msSaveOrOpenBlob 官方解释:Launches the associated application for a File or Blob.(启动File或Blob的关联应用程序)

解决方法:

var html =

'

' +document.getElementsByClassName("projectTable")[0].outerHTML +

"";var blob = new Blob([html], { type: "application/vnd.ms-excel"});//判断ie

if (window.navigator &&window.navigator.msSaveOrOpenBlob) {

window.navigator.msSaveOrOpenBlob(blob,"工程统计表.xls");

}else{var a = document.createElement("a");

a.href=URL.createObjectURL(blob);

a.download= "工程统计表.xls";

document.body.appendChild(a);

a.οnclick= function() {

document.body.removeChild(a);

};

a.click();

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值