html2canvas
2018-09-01 本文已影响0人
前端技术小哥
公司有个需求就是要在前端生成图片首先想到的是用canvas生成图片,自己画这也太耗时间了吧!后面在npm上一查有个html2canvas的框架可以用这里附上地址
使用起来也特别简单,官网是这么描述的
js
html2canvas(document.querySelector("#capture")).then(
canvas => {
document.body.appendChild(canvas)
});
html2canvas(document.querySelector("#capture") {async:true}).then(canvas => {document.body.appendChild(canvas)});
如果你要配置一些参数可以在传入dom的后面进行 object 传参 官网文档可查
我自己的工程环境是vue-cli会进行webpack打包在ios下运行的时候会出现错误因为我要生成一张图片是的canvas api 是 toDataURL
这错误在ios一直显示是权限问题 在ios 和safari 上的问题是一致的 原因是canva绘制dom上的图片的时候是 base64的格式(webpack会对asstes目录下的图片进行压缩)花费了几个小时才解决这个问题,感觉很不值所以分享给大家希望大家别踩进去了!解决方法是可以 static目录或者同域下的文件地址为了不出问题大家需把async 属性也加上