js通过URL下载⽂件
页⾯上⼀个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 被拦截
最想要的效果是点击下载按钮,原页⾯⽆改动⽆刷新,直接下载资源.移动版在新页⾯下载,触发下载⾃动关闭新页⾯.
解决办法:
两种⽅案:
ps基础教程视频
⼀ ,使⽤第⼀种⽅式,js构造a标签,js触发click.在a标签中加⼊download属性,(360安全浏览器兼容模式和IE浏览器可能还是会弹出空⽩页)
jsp页⾯:
aspire mc605主板电池在哪
1<div class="controls chzn-select fn-left">
2<button class="button button-flat-primary button-rounded"    type="button" id="export-self-static">导出表单大师查询成绩
3</button>
4</div>
5
6<a id="exportInfoForm" download><li id="ex-li">公式管理</li></a>
js页⾯:
1 $('#export-static').unbind('click').bind('click',function(){
portSelfStatistics();
3 });
4
5var 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请求
shell编程中是什么意思1 $('.download').click(function () {
2var tt = new Date().getTime();
3var url = '192.168.1.231:8080/91survey/ws/excel/download';
4/**
5* 使⽤form表单来发送请求
6* 1.method属性⽤来设置请求的类型——post还是get
7* 2.action属性⽤来设置请求路径。
8*
9*/
10var form=$("<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   */
27var input1=$("<input>");
28 input1.attr("type","hidden");
29 input1.attr("name","tt");
30 input1.attr("value",tt);
31 form.append(input1);
jquery下载文件请求32var input2=$("<input>");
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(){
2var tt =newDate().getTime();
3var url = restUrl +'/excel/download?userId='+ userId;
4var form=$("<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中
10var input1=$("<input>");
11 input1.attr("type","hidden");
12 input1.attr("name","tt");
13 input1.attr("value",tt);
14 form.append(input1);
15var input2=$("<input>");
16 input2.attr("type","hidden");
17 input2.attr("name","companyId");
18 input2.attr("value",companyId);
19 form.append(input2);
20 form.submit();//表单提交
21 });
完成后,在页⾯上⾯点击下载图标,⽂件就会⾃动下载了。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。