js通过html2canvas,jspdf,canvg来对网页进行截图生成pdf

2023-10-25 07:20

本文主要是介绍js通过html2canvas,jspdf,canvg来对网页进行截图生成pdf,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

通过html2canvas,jspdf就能够生成截图以及pdf,但是如果对图表(svg)就需要canvg来转换svg生成为图片,再插入到pdf里。

1.html2canvas用法:

首先需要引入这两个文件,最新的可以去git下载

示列:
function down2(){var str = $('#example-2');  
//console.log(str);  
html2canvas([str.get(0)], {scale: 1,onrendered: function (canvas) {  var image = canvas.toDataURL("image/png");  console.log(image);var pHtml = "<img src="+image+" />";  $('#pic').html(pHtml);  }  
});  }
<body><!-- `greet` 是在下面定义的方法名 --><button v-on:click="greet">Greet</button><button οnclick="down()">pdf</button><button οnclick="down2()">ok</button><button οnclick="exportPDF()">export</button><button οnclick="showQRCode()">showQRCode</button><div id="example-2"><div id="chart-container">FusionCharts will render here</div><div id="chart-container2">FusionCharts will render here</div><div id="chart-container3">FusionCharts will render here</div><div id="chart-container4">FusionCharts will render here</div></div><div id="all">
<canvas id='myCanvas01' /></canvas>
</div><div id="pic">
图片
</div>
<img src="" />
</body>

这就是一个最简单的截图示列。

2.jspdf生成pdf

需要引入jspdf.js

//l:横向, p:纵向; 单位: in:英寸,mm毫米;px:像素;  画布大小:默认是A4纸大小  var pdf = new jsPDF('p', 'mm', [230, 250]); //230 x 250  //添加字,以及字体大小设置pdf.setFontSize(40);pdf.text(35, 25, "乡村教师基本情况分析-现状");//添加图片pdf.addImage(img, 'JPEG', 20, 50, 200 , 200); //第3、4个参数是位置(x,y),距离左边20mm,上面50mm第5、6个参数是宽,高,宽200mm,高200mm    //保存pdf,名字是:分析报告.pdfpdf.save('分析报告.pdf');

其他参考资料:https://www.cnblogs.com/new_2050/p/8097867.html

3.通过canvg转换svg生成图片

需要引入以下文件:

$('#myCanvas01').show();//获取svgvar svgHtml = document.getElementById('chartobject-1').innerHTML;console.log(svgHtml)//转换canvg('myCanvas01',svgHtml);//生成图片$('#all').html2canvas({},function(imgData,w,h){$('#myCanvas01').hide();var pHtml = "<img src="+imgData+" />";  $('#pic').html(pHtml);  });
<body><!-- `greet` 是在下面定义的方法名 --><button v-on:click="greet">Greet</button><button οnclick="down()">pdf</button><button οnclick="down2()">ok</button><button οnclick="exportPDF()">export</button><button οnclick="showQRCode()">showQRCode</button><div id="example-2"><div id="chart-container">FusionCharts will render here</div><div id="chart-container2">FusionCharts will render here</div><div id="chart-container3">FusionCharts will render here</div><div id="chart-container4">FusionCharts will render here</div></div><div id="all">
<canvas id='myCanvas01' /></canvas>
</div><div id="pic">
图片
</div>
<img src="" />
</body>

2019.10.30更新

最近在GitHub上发现一个与html2canvas类似功能的dom转图片工具dom-to-image,鉴于二者比较:

html2canvas截图花费时长较多,且有cancas的dom节点可能出现截图不完整,因此推荐采用dom-to-image,二者用法类似。

这篇关于js通过html2canvas,jspdf,canvg来对网页进行截图生成pdf的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/280954

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)