问题
Is there any way to generate a PDF
file from HTML
page/content and the PDF
should be shown in bootstrap modal without downloading directly.
I tried using jsPDF
, but couldn't do as expected. Instead of bootstrap modal its showing in an iframe now.
Below is the sample HTML
content which is to be converted in to PDF
(without downloading) to show in Bootstrap Modal.
<body>
<Content will be displayed here>
</body>
Below is the javascript code(jsPDF).
<script src="https://html2canvas.hertzen.com/dist/html2canvas.js"></script>
<script src='../../dist/jspdf.debug.js'></script>
<script>
var pdf = new jsPDF('p', 'pt', 'letter');
pdf.html(document.body, {
callback: function (pdf) {
var iframe = document.createElement('iframe');
iframe.setAttribute('style', 'position:absolute;right:0; top:0; bottom:0; height:100%; width:500px');
document.body.appendChild(iframe);
iframe.src = pdf.output('datauristring');
}
});
</script>
回答1:
I reckon I have found a solution to your problem. Basically it takes a screenshot of your page with html2canvas
then it adds that image to to new jsPDF('p', 'pt', 'letter');
. Then it creates a bloburl
from the canvas to display it in an html <object data="bloburl">
in your modal. I have also added another function that makes it possible to download the pdf as well.
The relevant javascript:
//This will be the pdf object
let pdfFinal = null
function downloadPDF() {
pdfFinal.save("file.pdf");
}
function showPDF() {
//Create screenshot of body
html2canvas(document.body, {scale: 2,scrollY: -window.scrollY}).then(canvas => {
document.body.appendChild(canvas);
var imgData = canvas.toDataURL('image/png');
//add the image to pdf
var pdf = new jsPDF('L', 'pt', [canvas.width, canvas.height]);
pdf.addImage(imgData, 'PNG', 0, 0, canvas.width, canvas.height);
//set the pdfFinal to be later downloaded
pdfFinal = pdf;
//Get and set the output of the pdf
let output = pdf.output('bloburl');
document.getElementById("pdfObj").height = canvas.height / 4;
document.getElementById("pdfObj").data = output;
});
}
This code would have to be included in you <head>
:
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.1/js/bootstrap.min.js"></script>
<script src="https://html2canvas.hertzen.com/dist/html2canvas.js"></script>
<script src="https://unpkg.com/jspdf@latest/dist/jspdf.min.js"></script>
This modal code from (for simplicities sake) w3schools:
<div class="container">
<button type="button" onclick="showPDF();" class="btn btn-info btn-lg" data-toggle="modal" data-target="#myModal">Open Modal</button>
<div class="modal fade" id="myModal" role="dialog">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">×</button>
<h4 class="modal-title">Modal Header</h4>
</div>
<div class="modal-body">
<p>Here is your pdf.</p>
</div>
<center><object id="pdfObj" data="" type="application/pdf" width="90%" height="550">
</object></center>
<div class="modal-footer">
<button type="button" class="btn btn-info" onclick="downloadPDF();">Download</button>
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
</div>
</div>
</div>
</div>
</div>
Hope this helps! If not please comment
Edit
Now the entire page fits on the pdf. Changes: Added scaling for higher resolution
来源:https://stackoverflow.com/questions/62642087/show-pdf-generated-from-html-page-in-bootstrap-modal-without-downloading