1.項目中用到導出pdf,用到jsPDF,canvas,
2.網上很多方法,存在黑屏白屏,只能解決當前可視區域的問題
3.其中參考 https://blog.csdn.net/qq_36706878/article/details/111289963和https://blog.csdn.net/m0_37879526/article/details/103827235?utm_medium=distribute.pc_relevant_bbs_down.none-task--2~all~first_rank_v2~rank_v29-5.nonecase&depth_1-utm_source=distribute.pc_relevant_bbs_down.none-task--2~all~first_rank_v2~rank_v29-5.nonecase ,這兩位博友的博客,
使用方法:引入
<script src="https://cdn.bootcss.com/jspdf/1.5.3/jspdf.debug.js"></script>
<script src="https://cdn.bootcss.com/html2canvas/0.5.0-beta4/html2canvas.min.js"></script>
方法名
downloadC() {//方法名綁定你的導出按鈕
var _this = this;
var targetDom = $("#export_content");//你的目標元素id
var copyDom = targetDom.clone();
copyDom.width(targetDom.width() + "px");
copyDom.height(targetDom.height() + "px");
$('body').append(copyDom);
console.log('copyDom',copyDom)
html2canvas(copyDom, {
onrendered:function(canvas) {
var contentWidth = canvas.width;
var contentHeight = canvas.height;
var pageHeight = contentWidth / 592.28 * 841.89;
var leftHeight = contentHeight;
var position = 0;
var f="p";
// var imgWidth = 595.28;
// var imgHeight = 592.28/contentWidth * contentHeight;
var pageHeight = contentWidth / 592.28 * 841.89;
//未生成pdf的html頁面高度
var leftHeight = contentHeight;
//頁面偏移
var position = 0;
//a4紙的尺寸[595.28,841.89],html頁面生成的canvas在pdf中圖片的寬高
var imgWidth = 595.28;
var imgHeight = 592.28/contentWidth * contentHeight;
var pageData = canvas.toDataURL('image/jpeg', 1.0);
var pdf = new jsPDF('', 'pt', 'a4');
//有兩個高度需要區分,一個是html頁面的實際高度,和生成pdf的頁面高度(841.89)
//當內容未超過pdf一頁顯示的范圍,無需分頁
if (leftHeight < pageHeight) {
pdf.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight);
} else { // 分頁
while(leftHeight > 0) {
pdf.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight)
leftHeight -= pageHeight;
position -= 841.89;
// position += 841.89;
//避免添加空白頁
if(leftHeight > 0) {
pdf.addPage();
}
}
}
// contentHeight > contentWidth ? f = 'p' : f = 'l';
// var pageData = canvas.toDataURL('image/png', 1.0);
// _this.aaa = canvas.toDataURL();
// var pdf = new jsPDF(f, 'px', [imgWidth, imgHeight]);
// pdf.addImage(pageData, 'png', 0, 0, imgWidth, imgHeight);
pdf.save('content.pdf');
copyDom.remove();
}
});
},