一、html2canvas是什么?
根据html2canvas官方文档的介绍,html2canvas库的工作原理并不是真正的“截图”,而是读取网页上的目标DOM节点的信息来绘制canvas,所以它并不支持所有的css属性(详情参考这里),而且期望使用的图片跟当前域名同源,不过官方也提供了一些方法来解决跨域图片的加载问题。
二、使用步骤
1.npm或cnpm下载html2canvas包
npm install html2canvas
2.main.js方式引入
import html2canvas from 'html2canvas'
Vue.prototype.html2canvas = html2canvas
3.使用
html2canvas(document.body,{}).then(function(canvas) {
var imgUrl = canvas.toDataURL();
//imgUrl即为图片的base64形式
});
由于图片跨域问题 先将图片转成base64
阿里云OSS设置跨域,再截图
getBase64Image (url, ref) {
var that = this
var image = new Image()
image.src = url + '?v=' + Math.random() // 处理缓存
image.crossOrigin = '*' // 支持跨域图片
image.onload = function () {
var base64 = that.drawBase64Image(image)
that.$refs[ref].src = base64
}
},
drawBase64Image (img) {
var canvas = document.createElement('canvas')
canvas.width = img.width
canvas.height = img.height
var ctx = canvas.getContext('2d')
ctx.drawImage(img, 0, 0, img.width, img.height)
var dataURL = canvas.toDataURL('image/png')
return dataURL
},
776

被折叠的 条评论
为什么被折叠?



