本次技术调研来源于H5项目中的一个重要功能需求:实现微信长按网页保存为截图。
一、实现HTML页面保存为图片
1.1 已知可行方案
现有已知能够实现网页保存为图片的方案包括:
方案1:将DOM改写为canvas,然后利用canvas的toDataURL方法实现将DOM输出为包含图片展示的data URI
方案2:使用html2canvas.js实现(可选搭配Canvas2Image.js实现网页保存为图片)
方案3:使用rasterizeHTML.js实现
1.2 解决方案的选择
方案1:需要手动计算每个DOM元素的Computed Style,然后需要计算好元素在canvas的大小位置等属性。
方案1难点:
相当于完全重写了整个页面的布局样式,增加了工作量。
由于canvas中没有的对象概念,对于元素丰富、布局复杂的页面,不易重构。
所有DOM元素改写进canvas会带来一些困难,例如:难以支持响应式,图片元素清晰度不佳和文字点击区域识别问题等。
方案2:该类功能中Github上stars最多(至今仍在维护),Stack Overflow亦有丰富的讨论。只需简单调用html2canvas方法并设定配置项即可。
方案3:该方案的限制较多,目前仅支持3类可转为canvas的目标格式: 页面url,html字符串和document对象。
小结: html2canvas是目前实现网页保存为图片功能的综合最佳选择。
1.3 html2canvas的使用方法
以下描述针对html2canvas版本是0.5.0-beta4
1.3.1 实现保存为图片的第一步:html转为canvas
基于html2canvas.js可将一个元素渲染为canvas,只需要简单的调用html2canvas(element[, options]);即可。下列html2canvas方法会返回一个包含有元素的promise:
html2canvas(document.body).then(function(canvas) {
document.body.appendChild(canvas);
});
1.3.2 实现保存为图片的第二步:canvas转image
上一步生成的canvas即为包含目标元素的元素对象。实现保存图片的目标只需要将canvas转image即可