解决办法:
- 第一种:将传条件的以表单提交的方式进行(推荐这种)-----这种方式也可以用来页面跳转
$("#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‘)
ajax请求到一个controller在跳转到下载的controller上也不能下载,百度了一下总结下原因:发现原来jQuery的ajax回调已经把response的数据傻瓜式的以字符串的方式解析.