html2canvas图片位移_html2canvas生成的图片偏移不完整的解决方法

本文介绍了在使用html2canvas生成图片时遇到的偏移问题及其解决方法。通过设置配置参数scrolly和scrollx为0可以解决因页面滚动和transform属性导致的图片偏移。同时,提供了解决因transform:translateX(-50%)样式引起偏移的建议,即避免使用transform定位,改用其他方式如百分比或固定宽高。
摘要由CSDN通过智能技术生成

情景一:

问题背景:生成的图片在一个弹窗里面,如果页面没有滚动条就是正常的,但是一旦出现滚动条并且页面发生滚动时html2canvas绘制成的图片就会偏移出对应滚动高度的白边,如下:

解决办法:

楼主查了很多资料,也用了很多方法都没能解决这个问题,一气之下打算研究研究html2canvas的配置参数,果不其然,在配置参数renderoptions下找到如下配置

眼尖的楼主立马发现了scrolly这个东西。没错,这个肯定是配置偏移量的对吧,既然你是向下偏移我页面滚动的高度,那我把scrolly设置为负的那不就好了吗,说干就干。于是楼主设置了{scrolly: -window.pageyoffset},结果发生诡异的事,它倒是不向下偏移了,却开始向上偏移,如下

这个世界是怎么了,于是楼主又设置{scrolly: 0},再次查看,解决了。

原来,是因为在不设置scrolly的情况下,canvas绘制页面时会根据全局页面的滚动情况自动向下偏移。当然了,scrollx也是一样的道理。

奉上代码:

scrolly: 0, 其他的参数根据自己情况配置,这个参数一定不能少

var htmldom = document.getelementsbyclassname('dialog_content')[0];

html2canvas(htmldom, {

logging: false, //日志开关,便于查看html2canvas的内部执行流程

width: htmldom.clientwidth, //dom 原始宽度

height: htmldom.clientheight,

scrolly: 0,

scrollx: 0,

usecors: true // 【重要】开启跨域配置

}).then(canvas => {

var url = canvas.todataurl();//图片地址

htmldom.appendchild(canvas);

});

情景二:

用html2canvas绘制完图片后,始终会有个偏移距离,之前的解决办法是设scrolly: 0,scrollx: 0这两个参数为0,但是这次怎么弄都不行,最后排查出的原因是因为绘制的box上加了transform:translatex(-50%)这个样式。

解决办法:

用户绘图的区域不用transform来定位,换一种没有偏移的方式,比如设置百分比或者固定宽高。

到此这篇关于html2canvas生成的图片偏移不完整的解决方法的文章就介绍到这了,更多相关html2canvas生成图片偏移内容请搜索萬仟网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持萬仟网!

希望与广大网友互动??

点此进行留言吧!

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值