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


Posted in HTML / CSS onMay 19, 2020

情景一:

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

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

解决办法
 

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

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

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

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

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

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

原来,是因为在不设置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生成图片偏移内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
CSS3实现的闪烁跳跃进度条示例(附源码)
Aug 19 HTML / CSS
CSS3实现滚动条动画效果代码分享
Aug 03 HTML / CSS
CSS3 Calc实现滚动条出现页面不跳动问题
Sep 14 HTML / CSS
HTML5 自动聚焦(autofocus)属性使用介绍
Aug 07 HTML / CSS
HTML5实现预览本地图片
Feb 17 HTML / CSS
浅析HTML5的WebSocket与服务器推送事件
Feb 19 HTML / CSS
详解HTML5将footer置于页面最底部的方法(CSS+JS)
Oct 11 HTML / CSS
h5使用canvas画布实现手势解锁
Jan 04 HTML / CSS
关于html字符串正则判断和匹配的具体使用
Dec 12 HTML / CSS
css3 实现文字闪烁效果的三种方式示例代码
Apr 25 HTML / CSS
Html5获取用户当前位置的几种方式
Jan 18 HTML / CSS
解决flex布局中子项目尺寸不受flex-shrink限制
May 11 HTML / CSS
html5简介及新增功能介绍
May 18 #HTML / CSS
Html5让容器充满屏幕高度或自适应剩余高度的布局实现
May 14 #HTML / CSS
Html5在手机端调用相机的方法实现
May 13 #HTML / CSS
Html5页面获取微信公众号的openid的方法
May 12 #HTML / CSS
钉钉企业内部H5微应用开发详解
May 12 #HTML / CSS
html5 横向滑动导航栏的方法示例
May 08 #HTML / CSS
HTML5触摸事件(touchstart、touchmove和touchend)的实现
May 08 #HTML / CSS
You might like
php 应用程序安全防范技术研究
2009/09/25 PHP
PHP间隔一段时间执行代码的方法
2014/12/02 PHP
php 从指定数字中获取随机组合的简单方法(推荐)
2017/04/05 PHP
HTML DOM的nodeType值介绍
2011/03/31 Javascript
定时器(setTimeout/setInterval)调用带参函数失效解决方法
2013/03/26 Javascript
Extjs单独定义各组件的实例代码
2013/06/25 Javascript
运用jQuery定时器的原理实现banner图片切换
2014/10/22 Javascript
nodejs中操作mysql数据库示例
2014/12/20 NodeJs
基于javascript制作微信聊天面板
2020/08/09 Javascript
BootStrap table使用方法分析
2016/11/08 Javascript
jQuery中ajax错误调试分析
2016/12/01 Javascript
JS去除重复并统计数量的实现方法
2016/12/15 Javascript
jQuery实现联动下拉列表查询框
2017/01/04 Javascript
jQuery代码实现实时获取时间
2017/01/29 Javascript
基于VUE选择上传图片并页面显示(图片可删除)
2017/05/25 Javascript
jquery+ajaxform+springboot控件实现数据更新功能
2018/01/22 jQuery
封装微信小程序http拦截器过程解析
2019/08/13 Javascript
vue 自动化路由实现代码
2019/09/03 Javascript
Vue.extend 编程式插入组件的实现
2019/11/18 Javascript
JavaScript读取本地文件常用方法流程解析
2020/10/12 Javascript
python用reduce和map把字符串转为数字的方法
2016/12/19 Python
python条件变量之生产者与消费者操作实例分析
2017/03/22 Python
详解python 拆包可迭代数据如tuple, list
2017/12/29 Python
从列表或字典创建Pandas的DataFrame对象的方法
2019/07/06 Python
使用Django的JsonResponse返回数据的实现
2021/01/15 Python
世界排名第一的万圣节服装店:Spirit Halloween
2018/10/16 全球购物
俄罗斯药房连锁店:ASNA
2020/06/20 全球购物
JSF如何进行表格处理及取值
2012/08/06 面试题
请解释virtual关键字的含义
2015/06/17 面试题
优秀党员主要事迹
2014/01/19 职场文书
三分钟英语演讲稿
2014/04/24 职场文书
《陈毅探母》教学反思
2014/05/01 职场文书
领导班子整改方案
2014/10/25 职场文书
怀孕辞职信怎么写
2015/02/28 职场文书
2019大学生实习报告
2019/06/21 职场文书
CSS3通过var()和calc()函数实现动画特效
2021/03/30 HTML / CSS