温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何使用canvas保存网页为pdf文件支持跨域

发布时间:2021-05-28 14:06:44 来源:亿速云 阅读:426 作者:小新 栏目:web开发

这篇文章给大家分享的是有关如何使用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;  //一页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');  //有两个高度需要区分,一个是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;  //避免添加空白页  if (leftHeight > 0) {  pdf.addPage();  }  }  }  pdf.save('PDF的名字.pdf');  }  })  $('.sta-main').css("background", "") }) </script>

此次网页改为PDF,与上次截图网页为PNG,使用同一种技术,都是先使用Canvas截图画布后转格式。

同样也有偏移、模糊、跨域等问题,使用之前的代码来处理。

转换pdf会让背景色变为黑色使用css样式改一下背景色就可以了。

完美转换为pdf。

感谢各位的阅读!关于“如何使用canvas保存网页为pdf文件支持跨域”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI