博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js通过 URL下载文件
阅读量:5010 次
发布时间:2019-06-12

本文共 2718 字,大约阅读时间需要 9 分钟。

页面上一个button,点击之后触发一个function去请求数据,返回 pdf/epub 的URL,然后下载这个文件.

本来是直接用 a 写的,href里放资源地址,target设为'_blank'效果良好.但这样所有的资源都会直接暴露而且不方便统计,所以就换用上面的方式.

  1. js构造a标签,js触发click.不加_blank是可以的,但会替换掉原来整个页面.加了_blank chrome就拦截,Safari无效果.

  2. 用iframe,src填入资源地址. 但这样Safari无效果. 且,如果是MP4/pdf这样的文件浏览器并没有下载而是直接打开.

  3. window.open 被拦截

最想要的效果是点击下载按钮,原页面无改动无刷新,直接下载资源.移动版在新页面下载,触发下载自动关闭新页面.

解决办法:

两种方案:

一 ,使用第一种方式,js构造a标签,js触发click.在a标签中加入download属性,(360安全浏览器兼容模式和IE浏览器可能还是会弹出空白页)

jsp页面:

1 
2
4
5 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=$("
");//定义一个form表单11 form.attr("style","display:none");12 form.attr("target","");13 form.attr("method","get"); //请求类型14 form.attr("action",url); //请求地址15 $("body").append(form);//将表单放置在web中16   /**17 * input标签主要用来传递请求所需的参数:18 *19 * 1.name属性是传递请求所需的参数名.20 * 2.value属性是传递请求所需的参数值.21 *22 * 3.当为get类型时,请求所需的参数用input标签来传递,直接写在URL后面是无效的。23 * 4.当为post类型时,queryString参数直接写在URL后面,formData参数则用input标签传递24 * 有多少数据则使用多少input标签25 *26    */27 var input1=$("
");28 input1.attr("type","hidden");29 input1.attr("name","tt");30 input1.attr("value",tt);31 form.append(input1);32 var input2=$("
");33 input2.attr("type","hidden");34 input2.attr("name","companyId");35 input2.attr("value",companyId);36 form.append(input2);37 form.submit();//表单提交38 })

2)post请求

1 $('.download').click(function(){ 2 var tt =newDate().getTime(); 3 var url = restUrl +'/excel/download?userId='+ userId; 4 var form=$("
");//定义一个form表单 5 form.attr("style","display:none"); 6 form.attr("target",""); 7 form.attr("method","post");//请求类型 8 form.attr("action",url);//请求地址 9 $("body").append(form);//将表单放置在web中10 var input1=$("
");11 input1.attr("type","hidden");12 input1.attr("name","tt");13 input1.attr("value",tt);14 form.append(input1);15 var input2=$("
");16 input2.attr("type","hidden");17 input2.attr("name","companyId");18 input2.attr("value",companyId);19 form.append(input2);20 form.submit();//表单提交21 });

完成后,在页面上面点击下载图标,文件就会自动下载了。

转载于:https://www.cnblogs.com/zhouj850/p/9002124.html

你可能感兴趣的文章
maven用途、核心概念、用法、常用参数和命令、扩展
查看>>
linux时间同步ntp服务的安装与配置
查看>>
django.core.exceptions.ImproperlyConfigured: Requested setting DEFAULT_INDEX_TABLESPACE的解决办法...
查看>>
网络编程-socket并发-粘包问题
查看>>
python 中安装pandas
查看>>
Hibernate 的<generator class="native"></generator>的不同属性含义
查看>>
linux修改root账户的用户名所得的教训
查看>>
【LeetCode】Flatten Binary Tree to Linked List
查看>>
读后感-浮生六纪
查看>>
执行指定路径的程序文件
查看>>
Leetcode-950 Reveal Cards In Increasing Order(按递增顺序显示卡牌)
查看>>
[Linux] 在 Linux CLI 使用 ssh-keygen 生成 RSA 密钥
查看>>
14款下载有用脚本的超酷网站
查看>>
LXC-Linux Containers介绍
查看>>
7.31实习培训日志-docker sql
查看>>
c#中使用servicestackredis操作redis
查看>>
ios app 真机crash报告分析
查看>>
CRC标准以及简记式
查看>>
SEO搜索引擎
查看>>
关于本地使用tomcat部署web应用,浏览器自动跳转为https的问题
查看>>