您现在的位置是:网站首页> 编程资料编程资料
html2canvas生成的图片偏移不完整的解决方法html2canvas截图空白问题的解决使用html2canvas实现将html内容写入到canvas中生成图片html2 canvas生成清晰的图片实现打印功能html2canvas.js 实现页面截图html2 canvas svg不能识别的解决方案
2021-08-30
997人已围观
简介 这篇文章主要介绍了html2canvas生成的图片偏移不完整的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
情景一:
问题背景:生成的图片在一个弹窗里面,如果页面没有滚动条就是正常的,但是一旦出现滚动条并且页面发生滚动时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生成图片偏移内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
相关内容
- html5简介及新增功能介绍浅谈HTML5 FileReader分布读取文件以及其方法简介HTML与XHTML、以及HTML4与HTML5标签之间的区别简介HTML5的一个显示电池状态的API简介HTML5是什么 HTML5是什么意思 HTML5简介HTML5安全介绍之内容安全策略(CSP)简介HTML5的标签的代码的简单介绍 HTML5标签的简介html5新增的定时器requestAnimationFrame实现进度条功能HTML5新增加的功能详解iPhone5和iOS6上HTML5开发的新增功能
- HTML5中在title标题标签里设置小图标的方法html5移动端自适应布局的实现吃透移动端 Html5 响应式布局HTML5 通过Vedio标签实现视频循环播放的示例代码html5用video标签流式加载的实现详解HTML5 Canvas标签及基本使用html5自定义video标签的海报与播放按钮功能详解HTML5布局和HTML5标签
- Canvas 文本填充线性渐变的使用详解HTML5 canvas基本绘图之填充样式实现使用HTML5 Canvas为图片填充颜色和纹理的教程HTML5 Canvas如何实现纹理填充与描边(Fill And Stroke)HTML5 Canvas渐进填充与透明实现图像的Mask效果html5 Canvas画图教程(4)—未闭合的路径及渐变色的填充方法
- HTML5播放实现rtmp流直播使用HTML5加载音频和视频的实现代码Html5 webRTC简单实现视频调用的示例代码HTML5 video循环播放多个视频的方法步骤HTML5 通过Vedio标签实现视频循环播放的示例代码html5视频自动横过来自适应页面且点击播放功能的实现HTML5基于flash实现播放RTMP协议视频的示例代码
- HTML5实现应用程序缓存(Application Cache)Application Cache未缓存文件无法访问无法加载问题html5 application cache遇到的严重问题HTML5使用ApplicationCache接口实现离线缓存技术解决离线难题
- html5实现九宫格抽奖可固定抽中某项奖品jquery九宫格抽奖转盘特效源码ivx平台开发之不用代码实现一个九宫格抽奖功能
- HTML5页面无缝闪开的问题及解决方案html5实现点击弹出图片功能html5 录制mp3音频支持采样率和比特率设置html5表单的required属性使用html5调用摄像头实例代码HTML5页面音频自动播放的实现方式Html5大屏数据可视化开发的实现html实现弹窗的实例HTML5来实现本地文件读取和写入的实现方法HTML 罗盘式时钟的实现HTML5简单实现添加背景音乐的几种方法
- Html5导航栏吸顶方案原理与对比实现使用HTML+Css+transform实现3D导航栏的示例代码html+css+js实现导航栏滚动渐变效果html5 横向滑动导航栏的方法示例html+css 实现简易导航栏功能基于html和CSS3制作简单侧边导航栏基于html和CSS3制作酷炫的导航栏使用Html+Css实现简易导航栏功能(导航栏遇到鼠标切换背景颜色)
- 浅析图片上传及canvas压缩的流程使用canvas压缩图片上传的方法示例html5 canvas移动浏览器上实现图片压缩上传
- h5移动端调用支付宝、微信支付的实现基于HTML5+tracking.js实现刷脸支付功能详解Html5微信支付爬坑之路html5仿支付宝密码框的实现代码
