情景一:
问题背景:生成的图片在一个弹窗里面,如果页面没有滚动条就是 正常 的,但是一旦出现滚动条并且页面发生滚动时ht ML 2canvas 绘制 成的图片就会偏移出对应滚动高度的白边,如下:
&nbs p;
解决办法 :
楼主查了很多资料,也用了很多方法都没能解决这个问题,一气之下打算研究研究html2canvas的配置参数,果不其然,在配置参数RenderOptions下找到如下配置
眼尖的楼主立马发现了scrollY这个东西。没错,这个肯定是配置偏移量的对吧,既然你是向下偏移我页面滚动的高度,那我把scrollY设置为负的那不就好了吗,说干就干。于是楼主设置了 {scrollY: -window.pageYOffset} ,结果发生诡异的事,它倒是不向下偏移了,却 开始 向上偏移,如下
这个世界是怎么了,于是楼主又设置 {scrollY: 0} ,再次查看,解决了。
原来 ,是因为在不设置scrollY的情况下,canvas绘制页面时会根据全局页面的滚动情况自动向下偏移。当然了,scrollX也是一样的道理。
奉上代码:
scrollY: 0, 其他的参数根据自己情况配置,这个参数一定不能少
VAR htmlDom = document.getElementsBy classname ('dia LOG _content')[0]; html2canvas(htmlDom, { log gin g: false, //日志开关,便于查看html2canvas的内部执行流程 width: htmlDom.clientWidth, //dom 原始 宽 度 h ei ght: htmlDom.clientHeight, scrollY: 0, scrollX: 0, useCORS: true // 【 重要 】开启跨域配置 }).then(canvas => { var url = canvas.toDataURL();//图片地址 htmlDom.ap PE ndChild(canvas); });
情景二:
用html2canvas绘制完图片后,始终会有个偏移 距离 ,之前的解决办法是设 scrollY: 0,scrollX: 0 这两个参数为0,但是这次怎么弄都不行,最后排查出的 原因 是因为绘制的box上加了transform:trans latex (-50%)这个样式。
解决办法:
用户绘图的区域 不用 transform来定位,换一种没有偏移的方式,比如设置百分比 或者 固定宽高。
到此这篇关于html2canvas生成的图片偏移不完整的解决方法的 文章 就介绍到这了,更多相关html2canvas生成图片偏移内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
总结
以上是 为你收集整理的 html2canvas生成的图片偏移不完整的解决方法 全部内容,希望文章能够帮你解决 html2canvas生成的图片偏移不完整的解决方法 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。
查看更多关于html2canvas生成的图片偏移不完整的解决方法的详细内容...