PHP - 序列化表单数据并启动 Excel 下载
PHP - Serialize form data and initiate Excel download
序列化表单数据
//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
下载。
还有谁能解释一下我在这里做错了什么吗?
我认为你只需要更改这一行:
window.location.href = SITE_URL+"somecontroller/someAction?form_data="+str;
对此:
window.location.href = SITE_URL+"somecontroller/someAction?"+str;
序列化表单数据
//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
下载。
还有谁能解释一下我在这里做错了什么吗?
我认为你只需要更改这一行:
window.location.href = SITE_URL+"somecontroller/someAction?form_data="+str;
对此:
window.location.href = SITE_URL+"somecontroller/someAction?"+str;