页面上一个button,点击之后触发一个function去请求数据,返回 pdf/epub 的URL,然后下载这个文件.
本来是直接用 a 写的,href里放资源地址,target设为'_blank'效果良好.但这样所有的资源都会直接暴露而且不方便统计,所以就换用上面的方式.
-
js构造a标签,js触发click.不加_blank是可以的,但会替换掉原来整个页面.加了_blank chrome就拦截,Safari无效果.
-
用iframe,src填入资源地址. 但这样Safari无效果. 且,如果是MP4/pdf这样的文件浏览器并没有下载而是直接打开.
-
window.open 被拦截
最想要的效果是点击下载按钮,原页面无改动无刷新,直接下载资源.移动版在新页面下载,触发下载自动关闭新页面.
解决办法:
两种方案:
一 ,使用第一种方式,js构造a标签,js触发click.在a标签中加入download属性,(360安全浏览器兼容模式和IE浏览器可能还是会弹出空白页)
jsp页面:
12 45 6
js页面:
1 $('#export-static').unbind('click').bind('click',function(){2 exports.exportSelfStatistics();3 });4 5 var url = contextPath+"statistics/self/detail/export?" + new Date().getTime()+param;6 $('#exportInfoForm').attr("href", Util.appEncodeURL(url));7 $('#ex-li').trigger("click");
二,JQuery的ajax函数的返回类型只有xml、text、json、html等类型,没有“流”类型,所以我们要实现ajax下载,不能够使用相应的ajax函数进行文件下载。
但可以用js生成一个form,用这个form提交参数,并返回“流”类型的数据。在实现过程中,页面也没有进行刷新.(因为是动态生成的表单,静态的还是会刷新,要使用form.ajaxsubmit)
1)get请求
1 $('.download').click(function () { 2 var tt = new Date().getTime(); 3 var url = 'http://192.168.1.231:8080/91survey/ws/excel/download'; 4 /** 5 * 使用form表单来发送请求 6 * 1.method属性用来设置请求的类型——post还是get 7 * 2.action属性用来设置请求路径。 8 * 9 */10 var form=$("
2)post请求
1 $('.download').click(function(){ 2 var tt =newDate().getTime(); 3 var url = restUrl +'/excel/download?userId='+ userId; 4 var form=$("
完成后,在页面上面点击下载图标,文件就会自动下载了。