【发布时间】:2014-12-29 08:14:10
【问题描述】:
$objPHPExcel = new PHPExcel();
$objPHPExcel->getActiveSheet()->setTitle('TestMessages');
header('Content-Type: application/vnd.ms-excel');
header("Content-Disposition: attachment; filename=test_form_".date("Y-m-d_H:i:s").".xls");
// If you're serving to IE 9, then the following may be needed
header('Cache-Control: max-age=1');
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');
当我直接从浏览器调用上述代码时,结果文件被下载。但是如果我对上面的代码进行 ajax 调用,我不会得到下载提示。我可以从控制台选项卡中看到 ajax 调用已成功完成,并且在响应数据中看到了一堆随机字符。我假设那是 excel 对象。
有谁知道如何使用 ajax 实现下载 excel 功能?我不想刷新页面。当用户点击“导出”按钮时,应该有一个对php文件的ajax调用,并提示用户下载。
我参考Passing data from PHP class to PHPExcel via AJAX但不明白如何实现我的目标?
【问题讨论】:
-
您可以在页面中添加隐藏的 iframe。当 ajax 调用返回创建数据的 url 时,使用 javascript 将 iframe 重定向到自动触发下载操作的 url。