明天的明天 永远的永远 未知的一切 我与你一起承担 ??

是非成败转头空 青山依旧在 几度夕阳红 。。。
  博客园  :: 首页  :: 管理

解决办法:

  • 第一种:将传条件的以表单提交的方式进行(推荐这种)-----这种方式也可以用来页面跳转
            $("#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')