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中box属性中的overflow-x属性和overflow-y属性值的效果
Jul 21 HTML / CSS
CSS3让登陆面板3D旋转起来
May 03 HTML / CSS
CSS3绘制六边形的简单实现
Aug 25 HTML / CSS
html5的自定义data-*属性与jquery的data()方法的使用
Jul 02 HTML / CSS
实例教程 利用html5和css3打造一款创意404页面
Oct 20 HTML / CSS
HTML5标签使用方法详解
Nov 27 HTML / CSS
详解html5 canvas常用api总结(二)--绘图API
Dec 14 HTML / CSS
遮罩层 + Iframe实现界面自动显示的示例代码
Apr 26 HTML / CSS
HTML5 HTMLCollection和NodeList的区别详解
Apr 29 HTML / CSS
css position fixed 左右双定位的实现代码
Apr 29 HTML / CSS
HTML5页面音频自动播放的实现方式
Jun 21 HTML / CSS
CSS控制继承中的height能变为可继承吗
Jun 10 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
2019年漫画销量排行榜:鬼灭登顶 海贼单卷制霸 尾田盛赞鬼灭
2020/03/08 日漫
PHP 配置文件中open_basedir选项作用
2009/07/19 PHP
PHP获取网址的顶级域名函数代码
2012/09/24 PHP
PHP base64编码后解码乱码的解决办法
2014/06/19 PHP
php对关联数组循环遍历的实现方法
2015/03/13 PHP
如何在HTML 中嵌入 PHP 代码
2015/05/13 PHP
JavaScript中令你抓狂的魔术变量
2006/11/30 Javascript
Extjs中通过Tree加载右侧TabPanel具体实现
2013/05/05 Javascript
Jquery中LigerUi的弹出编辑框(实现方法)
2013/07/09 Javascript
js调用iframe实现打印页面内容的方法
2014/03/04 Javascript
Node.js中使用计时器定时执行函数详解
2014/08/15 Javascript
Windows8下搭建Node.js开发环境教程
2014/09/03 Javascript
用原生js统计文本行数的简单示例
2016/08/19 Javascript
vue.js中过滤器的使用教程
2017/06/08 Javascript
vue-lazyload使用总结(推荐)
2018/11/01 Javascript
15分钟深入了解JS继承分类、原理与用法
2019/01/19 Javascript
vue.js+element 默认提示中英文操作
2020/11/11 Javascript
[01:13]2014DOTA2西雅图邀请赛 舌尖上的TI4
2014/07/08 DOTA
轻松掌握python设计模式之访问者模式
2016/11/18 Python
简单谈谈Python的pycurl模块
2018/04/07 Python
python实现事件驱动
2018/11/21 Python
Python 移动光标位置的方法
2019/01/20 Python
python 将字符串完成特定的向右移动方法
2019/06/11 Python
python爬虫学习笔记之pyquery模块基本用法详解
2020/04/09 Python
X/HTML5 和 XHTML2
2008/10/17 HTML / CSS
Spanx塑身衣官网:美国知名内衣品牌
2017/01/11 全球购物
爱他美官方海外旗舰店:Aptamil奶粉
2017/12/22 全球购物
大学生专科毕业生自我评价
2013/11/17 职场文书
宝宝周岁宴答谢词
2014/01/26 职场文书
幼儿园教学随笔感言
2014/02/23 职场文书
铲车司机岗位职责
2014/03/15 职场文书
绩效管理实施方案
2014/03/19 职场文书
电子装配专业毕业生求职信
2014/04/23 职场文书
医院党的群众路线教育实践活动领导班子对照检查材料
2014/09/25 职场文书
兵马俑导游词
2015/02/02 职场文书
学校清洁工岗位职责
2015/04/15 职场文书