序列化表单数据
//start excel download
$("#btn_excel").click(function(){
var str = $("#my-form").serialize();
window.location.href = SITE_URL+"somecontroller/someAction?form_data="+str;
});
//end excel download
生成的查询字符串
start_date=1-Jul-15&end_date=1-Aug-15&id=11&description=My+Description&project_name_selected=Amazon+AWS
要获取输出,我已经在下面使用但是这不起作用
parse_str($_GET['form_data'], $output);
print_r($output);
输出
Array
(
[form_data] => start_date=1-Jul-15
[end_date] => 1-Aug-15
[id] => 11
[description] => My Description
[project_name_selected] => Amazon+AWS
)
如您所见,查询字符串已损坏且无法正确提取数据。
尝试下面,但这不会起作用,因为我需要通过Ajax启动下载;作为正常的Ajax响应,响应将在以太中消失。
$.post(SITE_URL+"somecontroller/someAction",str, function( data ) {
});
我直接将浏览器导向资源,这将自动检测到它是要下载的文件,并启动下载。
如何传递序列化表单数据并获取输出以启动Excel
下载。
也有人可以请问我在这里做错了什么?
答案 0 :(得分:0)
我认为你只需改变这一行:
window.location.href = SITE_URL+"somecontroller/someAction?form_data="+str;
到此:
window.location.href = SITE_URL+"somecontroller/someAction?"+str;