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和jquery实现自定义checkbox和radiobox组件
Apr 22 HTML / CSS
举例详解CSS3中的Transition
Jul 15 HTML / CSS
CSS3中的常用选择器使用示例整理
Jun 13 HTML / CSS
浅谈css3中的前缀
Jul 20 HTML / CSS
CSS3 rgb and rgba(透明色)的使用详解
Sep 25 HTML / CSS
HTML中使用SVG与SVG预定义形状元素介绍
Jun 28 HTML / CSS
一些常用的HTML5模式(pattern) 总结
Jul 14 HTML / CSS
详解html5 canvas 微信海报分享(个人爬坑)
Jan 12 HTML / CSS
Html5 APP中监听返回事件处理的方法示例
Mar 15 HTML / CSS
Html5定位终极解决方案
Feb 05 HTML / CSS
HTML速写之Emmet语法规则的实现
Apr 07 HTML / CSS
详解CSS故障艺术
May 25 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
DC《神奇女侠2》因疫情推迟上映 温子仁新恐怖片《恶性》撤档
2020/04/09 欧美动漫
PHP新手上路(六)
2006/10/09 PHP
PHP 分页类(模仿google)-面试题目解答
2009/09/13 PHP
php中模拟POST传递数据的两种方法分享
2011/09/16 PHP
PHP自动重命名文件实现方法
2014/11/04 PHP
WordPress中制作导航菜单的PHP核心方法讲解
2015/12/11 PHP
PHP抓取远程图片(含不带后缀的)教程详解
2016/10/21 PHP
php实现的中秋博饼游戏之绘制骰子图案功能示例
2017/11/06 PHP
JS 跳转页面延迟2种方法
2013/03/29 Javascript
Jquery注册事件实现方法
2015/05/18 Javascript
Node.js模块封装及使用方法
2016/03/06 Javascript
基于JavaScript实现鼠标向下滑动加载div的代码
2016/08/31 Javascript
微信小程序 配置文件详细介绍
2016/12/14 Javascript
canvas实现图像截取功能
2017/02/06 Javascript
基于JavaScript实现移动端无限加载分页
2017/03/27 Javascript
vue深入解析之render function code详解
2017/07/18 Javascript
Windows下Node.js安装及环境配置方法
2017/09/18 Javascript
深入理解Node内建模块和对象
2019/03/12 Javascript
Vue+Typescript中在Vue上挂载axios使用时报错问题
2019/08/07 Javascript
vue-cli和v-charts实现可视化图表过程解析
2019/10/08 Javascript
Python实现短网址ShortUrl的Hash运算实例讲解
2015/08/10 Python
Python中str is not callable问题详解及解决办法
2017/02/10 Python
python编写分类决策树的代码
2017/12/21 Python
教你用一行Python代码实现并行任务(附代码)
2018/02/02 Python
python数字图像处理之骨架提取与分水岭算法
2018/04/27 Python
Python安装lz4-0.10.1遇到的坑
2018/05/20 Python
Python读取Excel表格,并同时画折线图和柱状图的方法
2018/10/14 Python
Python实现对adb命令封装
2020/03/06 Python
Python unittest框架操作实例解析
2020/04/13 Python
Python的Django框架实现数据库查询(不返回QuerySet的方法)
2020/05/19 Python
美国轻奢时尚购物网站:REVOLVE(支持中文)
2020/07/18 全球购物
教师对学生的寄语
2014/04/03 职场文书
我爱读书演讲稿
2014/05/07 职场文书
毕业班工作总结
2015/08/10 职场文书
2016年“我们的节日·重阳节”主题活动总结
2016/04/01 职场文书
阿里云服务器部署mongodb的详细过程
2021/09/04 MongoDB