一、实现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的使用方法
官方GitHub:https://github.com/niklasvh/h…
以下描述针对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即可。
这里的转换方案有2种:
**方案1:**基于