我正在DomPDFLaravel 项目上使用 Ajax Post 请求处理“ ”。下面是ajax代码。
$.ajaxSetup({
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
}
});
$.ajax({
url:"{{ route('screen.pdfticket') }}",
method:"POST",
data:{
id:$('#screenid').val()
},
success:function(data){
console.log(data);
}
});
Run Code Online (Sandbox Code Playgroud)
下面是控制器中的代码。
$customPaper = array(0,0,216,158);
$pdf->loadView("screen.ticket" , [
'clinic' => 'clinic name' ,
'queno' => $screen->que
])->setPaper($customPaper, 'landscape');
return $pdf->download($screen->que .'.pdf');
Run Code Online (Sandbox Code Playgroud)
我可以得到正确的响应,但它不是可读的格式。我想在 ajax 调用成功后以 pdf 格式保存。任何建议或指导将不胜感激,谢谢。
由于您使用 AJAX 发出请求,因此您需要一种让浏览器加载资源的方法。
有一些方法可以但不限于以下:
在对 AJAX 请求的响应中返回资源 URL,然后发出单独的浏览器请求以加载资源。
对 AJAX 请求生成资源响应的 blob,然后从 blob 的 URL 加载它。
这在下面的示例中显示。
function downloadFile(response) {
var blob = new Blob([response], {type: 'application/pdf'})
var url = URL.createObjectURL(blob);
location.assign(url);
}
$.ajax({
url: "{{ route('screen.pdfticket') }}",
method: 'POST',
data: {
id: $('#screenid').val()
}
})
.done(downloadFile);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3734 次 |
| 最近记录: |