问题场景:工做中实现数据导出功能,客户把数据加载处理以后勾选所有,而后进行导出操做。发现出现页面没法显示问题。浏览器
问题分析:开发过程当中因为开发环境测试数据有限,勾选少数数据导出均可以正常导出。经过详细测试以后,当勾选的记录条数超过某个限制以后就会出现请求无效。此时问题大概定位就是和传递的参数有关系。post
因而跟踪代码查看原来代码导出的实现方式,发现若是勾选了数据则是在前台组装ids,而后经过url的方式传递到后台。后台根据ids获取全部记录回填到excel中。可是咱们都知道经过url发起请求时,长度是有限制的。具体长度限制和浏览器等因素有关。ie支持的长度最长支持2083,其余浏览器支持更长。当长度超过了请求就会无效。测试
解决办法:url长度有限制,那么咱们只能改用其余方式发请求了,使用最原始的表单提交方式进行。注意:使用表弟提交方式时:注意要把method属性改为post方式,由于get方式提交数据时,参数仍是会跟在url后面,从而产生一样的问题。url
表单提交实现方式:excel
document.form[0].action=actionurl;orm
document.form[0].method.value=export开发
document.form[0].submit();get
经过这样去执行action中的export方法,就不会出现因为数据过多而致使请求无效问题。it