在网页上生成一个便于用户分享的精美海报,或者对于网页内容生成截图,现在已经是一个非常常见的需求,现在怎么实现呢?
生成网页截图和海报一般都有两种做法,一是服务端使用 GD 库生成,二是前端使用 Canvas 生成,但是这两种方法都比较麻烦。
服务端通过 GD 库去生成的话,首先要去查 GD 库相关的大量函数,然后图片的坐标,文字的换行等等都要仔细去算,一点点修改,都要重新算一遍,非常难受。
而前端使用 Canvas 生成的话,就需要熟悉 Canvas 的语法,它的 API 比较复杂,有大量的方法和属性,让很多希望通过 Canvas 画图的同学望而却步。
那么有没有什么简单的方法生成海报呢?不需要学习太多新知识,利用现有的知识就实现的呢?
有的,html2canvas 就是这样的一个 Javascript 库,无需大量学习,只需要会 HTML 和 CSS 即可,html2canvas 可以把网页元素或者整个网页转换为一个 Canvas 对象或者图片。
html2canvas 是通过在浏览器端解析 HTML 和 CSS 来实现这个功能,不需要任何服务器端的支持,然后也不需要对 Canvas 相关的方法深入的学习,只需要懂的简单的 HTML 和 CSS 即可。
总结一下,下面是 html2canvas
的一些主要优势:
html2canvas
完全在客户端运行,无需任何服务器端的支持。这使得它非常适合在各种环境中使用,包括静态网页和单页应用。html2canvas
还支持多种 CSS 属性,包括 z-index
、overflow
、CSS transforms
和 CSS filters
等。html2canvas
支持所有主流的浏览器,包括 Chrome、Firefox、Safari 和 IE11+。html2canvas
提供了一系列的选项和API,使得你可以对截图过程进行深度定制,包括修改截图的尺寸、忽略特定元素、添加背景颜色等。html2canvas
是开源的,你可以查看和修改它的源代码,甚至为它贡献代码。但是也需要注意的是,由于 html2canvas
是通过解析 HTML 和 CSS 来生成截图的,所以它无法完美地复制所有的渲染效果,特别是一些复杂的 CSS 样式和动态内容。
首先加载 html2canvas 对应的 JavaScript 库:
<script type='text/javascript' src='https://cdn.staticfile.org/html2canvas/1.4.1/html2canvas.js'></script>
然后选择对应的网页元素生成屏幕截图:
html2canvas(document.querySelector("#capture")).then(canvas => {
document.body.appendChild(canvas)
});
就是这么简单,只需几行代码就行!