码迷,mamicode.com
首页 > 其他好文 > 详细

文件下载的ie11兼容性优化

时间:2018-03-01 17:20:58      阅读:213      评论:0      收藏:0      [点我收藏+]

标签:doc   浏览器兼容   分享图片   end   response   技术   个人   技术分享   www   

  在 http://www.cnblogs.com/sunshine6/p/8296945.html 中有说关于前后端分离时如何实现文件下载的功能,但是过完年回来,同事告诉我这个方式在ie11上存在不兼容的问题,报如下错:

技术分享图片

  浏览器兼容问题是很头疼的问题,因为之前也没遇到过这样的问题,所以经过两三个小时才解决。

  发现在微软在ie10 和ie11中有两个特有的方法:window.navigator.msSaveBlobwindow.navigator.msSaveOrOpenBlob 方法,这两个方法的区别在于,前者只有保存,后者有保存和打开两个选项,按个人喜好使用就行。

  优化之后的代码如下:

 1  /**
 2      * 导出用户列表
 3      */
 4     private exportUsers(){
 5         this.http.doPost({
 6             url: ‘system/sysmanager/user/exportUsers‘,
 7             responseType:ResponseContentType.Blob,
 8             body:this.form,
 9             success: (req, res) => {
10                 if(window.navigator.msSaveOrOpenBlob){
11                     // 兼容ie11
12                     try{
13                         var blobObject = new Blob([res.json()]); 
14                         window.navigator.msSaveOrOpenBlob(blobObject, "用户列表.xlsx"); 
15                     }
16                     catch(e){
17                         console.log(e);
18                     }
19                 }
20                 else{
21                     var blob = new Blob([res.json()]); 
22                     var a = document.createElement(‘a‘);
23                     a.href = URL.createObjectURL(blob); // xhr.response is a blob
24                     a.download = "用户列表.xlsx";
25                     a.style.display = ‘none‘;
26                     document.body.appendChild(a);
27                     a.click();
28                     a.remove();
29                 }
30             }
31         });
32    }

 

  如果有什么不当之处,请大家多多指出。

 

文件下载的ie11兼容性优化

标签:doc   浏览器兼容   分享图片   end   response   技术   个人   技术分享   www   

原文地址:https://www.cnblogs.com/sunshine6/p/8488545.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!