详解应用canvas储存网页页面为pdf文档适用跨域

日期:2020-10-13 类型:科技新闻 

关键词:建站平台有哪些,如何建设网站,免费自助建站,如何建立一个网站,网站建站的

序言

以前上1篇随笔说了Canvas截图网页页面为照片,下来个新要求,把网页页面截图后储存为PDF文档供客户免费下载。

应用canvas储存网页页面为pdf文档适用跨域

文章正文

要求:客户点一下免费下载,将网页页面储存为PDF文档并免费下载。

思路:再次应用Canvas截图后将画布內容变换为pdf文档。

最先大家必须引进js文档jspdf.debug.js 免费下载相对路径 https://github.com/MrRio/jsPDF

引进canvas的js文档,js文档获得详细地址官方网站首页:http://html2canvas.hertzen.com/

<script type="text/javascript" src="js/html2canvas.js"></script>
<script type="text/javascript" src="js/html2canvas.min.js"></script>
<script type="text/javascript" src="js/jspdf.debug.js"></script>

div按钮编码

 <div id="down_pdf">导出来为PDF按钮</div>
 <div class="sta-main">必须获得为PDF的div</div>

jsp编码

<script type="text/javascript">
/* var downPdf = document.getElementById("down_pdf"); */
var downPdf = document.getElementById("down_pdf");
$("#down_pdf").on("click", function() {
 var canvas2 = document.createElement("canvas");
 let _canvas = document.querySelector('.sta-main');
 //获得宽高
 var w = parseInt(window.getComputedStyle(_canvas).width);
 var h = parseInt(window.getComputedStyle(_canvas) .height);
 //将canvas画布变大2倍,随后盛装在小的器皿内,解决模糊不清
 canvas2.width = w * 2;
 canvas2.height = h * 2;
 canvas2.style.width = w + "px";
 canvas2.style.height = h + "px";
 var context = canvas2.getContext("2d");
 //解决偏位
 context.scale(1.5, 1.5);
 //改动情况色调,默认设置是黑色
 $('.sta-main').css("background", "#fff")
 html2canvas( _canvas, {
 //解决pdf跨域获得不到跨域信息内容难题
 taintTest : false,
 useCORS : true,
 allowTaint : false, 
 canvas : canvas2,
 dpi: 172,//导出来pdf清楚度
 onrendered: function (canvas) {
 var contentWidth = canvas.width;
 var contentHeight = canvas.height;
 //1页pdf显示信息html网页页面转化成的canvas高宽比;
 var pageHeight = contentWidth / 592.28 * 841.89;
 //未转化成pdf的html网页页面高宽比
 var leftHeight = contentHeight;
 //pdf网页页面偏位
 var position = 0;
 //html网页页面转化成的canvas在pdf中照片的宽高(a4纸的规格[595.28,841.89])
 var imgWidth = 595.28;
 var imgHeight = 592.28 / contentWidth * contentHeight;
 var pageData = canvas.toDataURL('image/jpeg', 1.0);
 var pdf = new jsPDF('', 'pt', 'a4');
 //有两个高宽比必须区别,1个是html网页页面的具体高宽比,和转化成pdf的网页页面高宽比(841.89)
 //当內容未超出pdf1页显示信息的范畴,不用分页查询
 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;
 //防止加上空白页
 if (leftHeight > 0) {
 pdf.addPage();
 }
 }
 }
 pdf.save('PDF的姓名.pdf');
 }
 })
 $('.sta-main').css("background", "")
})
</script> 

此次网页页面改成PDF,与之前截图网页页面为PNG,应用同1种技术性,全是先应用Canvas截绘画布后转文件格式。

一样也是有偏位、模糊不清、跨域等难题,应用以前的编码来解决。

变换pdf会让情况色变成黑色应用css款式改1下情况色便可以了。

完善变换为pdf。

以上便是本文的所有內容,期待对大伙儿的学习培训有一定的协助,也期待大伙儿多多适用脚本制作之家。