微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ajax请求到一个controller在跳转到下载的controller上也不能下载,百度了一下总结下原因:发现原来jQuery的ajax回调已经把response的数据傻瓜式的以字符串的方式解析.

解决办法:

  • 第一种:将传条件的以表单提交的方式进行(推荐这种)-----这种方式也可以用来页面跳转
            $("#queryCourseForm").attr("action",contextpath+"/downCourses.do");//改变表单的提交地址为下载的地址
            $("#queryCourseForm").submit();//提交表单

 

  • 第二种:以window.location.href="xxx"的方式请求下载地址
            window.location.href=contextpath+"/downCourses.do"

  这种方法需要自己手动的拼接地址传递参数。get请求携带参数的方式:   xxxx.html?username=xxx&password=xxxx

 

  • 第三种:动态创建表单加到fbody中,最后删除表单(推荐这种,可以将组合条件的值也动态的加入表单中)

复制代码

    //动态创建表单加到fbody中,最后删除表单
    var queryForm = $("#queryCourseForm");
    var exportForm = $("<form action='/downCourses.do' method='post'></form>")     
    exportForm.html(queryForm.html());
    $(document.body).append(exportForm);
    exportForm.submit();
    exportForm.remove();

复制代码

注意:动态form必须加到DOM树,否则会报异常:Form submission canceled because the form is not connected。而且提交完需要删除元素。

 

 

 

补充:    有时候上面查询条件到不了第二个动态表单中,需要手动添加查询条件到表单中,如下:

复制代码

function extTaizhang(){
    //动态创建表单加到fbody中,最后删除表单
    var queryForm = $("#queryTaizhangForm");
    var exportForm = $("<form action='"+baseurl+"/extSafeHatTaizhang.do' method='post'></form>")     
    
    exportForm.append("<input type='hidden' name='userName' value='"+$("[name='userName']").val()+"'/>")
    exportForm.append("<input type='hidden' name='idCard' value='"+$("[name='idCard']").val()+"'/>")
    exportForm.append("<input type='hidden' name='safeHatNum' value='"+$("[name='safeHatNum']").val()+"'/>")
    alert(exportForm.serialize());
    $(document.body).append(exportForm);
    exportForm.submit();
    exportForm.remove(); 
}

复制代码

 

 

调用代码:

exportExcel('listPageForm', 'extOperationCharge.do')

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐