zoukankan      html  css  js  c++  java
  • 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 被拦截

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

    解决办法:

    两种方案:

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

    jsp页面:

    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" style="display: none;" download><li id="ex-li">公式管理</li></a>

    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>");//定义一个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=$("<input>");
    28 input1.attr("type","hidden");
    29 input1.attr("name","tt");
    30 input1.attr("value",tt);
    31 form.append(input1);
    32 var 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(){
     2 var tt =newDate().getTime();
     3 var url = restUrl +'/excel/download?userId='+ userId;
     4 var 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中
    10 var input1=$("<input>");
    11 input1.attr("type","hidden");
    12 input1.attr("name","tt");
    13 input1.attr("value",tt);
    14 form.append(input1);
    15 var 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 });

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

  • 相关阅读:
    关联原理说明
    一个软件测试工程师的学习体验
    缺陷漏测分析:测试过程改进
    自动化测试的7个步骤
    ACM题目————Subsequence
    ACM题目————Aggressive cows
    ACM题目————列变位法解密
    C++TSL之map容器(悲伤的故事)
    ACM题目————二叉树最大宽度和高度
    ACM题目————装箱问题
  • 原文地址:https://www.cnblogs.com/zhouj850/p/9002124.html
Copyright © 2011-2022 走看看