我们有一种有趣的方式来使用自定义的内部框架来做 ajax,本质上是在我做的一些 javascript 函数中:
CT.postSynch('report/index/downloadProjectsInProgress', {}, function(data){
});
这告诉 ajax 寻找一个名为 的模块Report
、一个名为 的控制器Index
和一个名为ajazDownloadProjectInprogress
我写了一个函数 ajazDownloadProjectInprogress,它所做的只是根据我得到的一些数据创建一个简单的 PDF。在该函数中,我有以下内容(使用 DOMPDF),如下所示:
$dompdf = new DOMPDF();
$content = $this->raw('./report.header','./projectsInProgressReport','./report.footer');
$dompdf->load_html($content);
$dompdf->render();
$dompdf->output();
header('Pragma:');
header('Cache-Control: private,no-cache');
return $dompdf->stream("Structure Report - ProgressReports.pdf", array('Attachment' => 1));
我在这里所做的只是根据我们将视图呈现为 html 或原始数据的方式获取一些内容,并尝试通过 ajax 将 pdf 流式传输回来。
在上面的代码中,我向您展示了我们如何处理 ajax 调用,我做了:
CT.postSynch('report/index/downloadProjectsInProgress', {}, function(data){
return data;
});
现在网络选项卡向我显示:
%PDF-1.3
1 0 obj
<< /Type /Catalog
/Outlines 2 0 R
/Pages 3 0 R >>
endobj
2 0 obj
<< /Type /Outlines /Count 0 >>
endobj
3 0 obj
<< /Type /Pages
/Kids [6 0 R
]
/Count 1
/Resources <<
/ProcSet 4 0 R
/Font <<
/F1 8 0 R
/F2 9 0 R
>>
/XObject <<
/I1 10 0 R
/I2 11 0 R
这只是返回的内容的一个示例....
任何人都知道您打算如何通过 ajax 调用下载 PDF?我知道 ajax 它本身不会下载文件 - 但我设置了所有内容,以便该功能应该只是开始下载过程。