Экспорт HTML в PDF в JavaScript
Я использовал html2canvas для создания PDF из HTML
Результат: он генерирует карту без пути
Вот что у меня есть:
html2canvas(document.getElementById('pdf-canvas'), {
onrendered: function (canvas) {
var data = canvas.toDataURL("image/png");
var docDefinition = {
content: [{
image: data,
width: 500,
}]
};
pdfMake.createPdf(docDefinition).download("Score_Details.pdf");
}
});
Тогда я использовал канвг и ткань
Результат: он генерирует путь без карты
Вот что у меня есть
1)fabric
var canvas = new fabric.StaticCanvas( undefined, {
width: 500,
height: 500,
} );
var svgEl = document.body.getElementsByTagName('svg')[0];
var serializer = new XMLSerializer();
var svgStr = serializer.serializeToString(svgEl);
var path = fabric.loadSVGFromString(svgStr,function(objects, options) {
var obj = fabric.util.groupSVGElements(objects, options);
canvas.add(obj).renderAll();
var data = canvas.toDataURL();
var docDefinition = {
content: [{
image: data,
width: 500,
}]
};
pdfMake.createPdf(docDefinition).download("Score_Details.pdf");
});
2)canvg
var svgImage = document.body.getElementsByTagName('svg')[0];
var serializer = new XMLSerializer();
var str = serializer.serializeToString(svgImage);
var $canvas = $('<canvas/>');
$canvas.attr('width', '150px;')
$canvas.attr('height', '150px;')
$canvas.appendTo('body');
canvg($canvas.get(0), str);
html2canvas($canvas, {
onrendered: function (canvas) {
var a = document.createElement('a');
a= canvas.toDataURL();
var docDefinition = {
content: [{
image: a,
width: 500,
}]
};
pdfMake.createPdf(docDefinition).download("Score_Details.pdf");
$canvas.remove(); //removes canvas from body
}
});
Нужно ли использовать другую библиотеку или я что-то пропустил, используя html2canvas, canvg и fabric?
2 ответа
J'ai testé jsPDF mais j'arrive toujours pas à générer le trajet voici le code
html2canvas(document.getElementById("pdf-canvas"), {
onrendered: function(canvas) {
var imgData = canvas.toDataURL('image/png');
console.log('Report Image URL: '+imgData);
var doc = new jsPDF('p', 'mm', [297, 210]); //210mm wide and 297mm high
doc.addImage(imgData, 'PNG', 10, 10);
doc.save('sample.pdf');
}
});
Я нашел библиотеку для экспорта в PDF-файл, вы можете попробовать ее. jsPDF