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 响应式媒体查询的示例代码
Sep 25 HTML / CSS
html5 css3 动态气泡按钮实例演示
Dec 02 HTML / CSS
用css3实现当鼠标移进去时当前亮其他变灰效果
Apr 08 HTML / CSS
CSS3实现的文本3D效果附图
Sep 03 HTML / CSS
结合CSS3的布局新特征谈谈常见布局方法
Jan 22 HTML / CSS
通过CSS3的object-fit来调整图片适配尺寸的技巧简介
Feb 27 HTML / CSS
CSS3制作炫酷的下拉菜单及弹起式选单的实例分享
May 17 HTML / CSS
html5文本内容_动力节点Java学院整理
Jul 11 HTML / CSS
极简的HTML5模版
Jul 09 HTML / CSS
HTML5几个设计和修改的页面范例分享
Sep 29 HTML / CSS
html+js 实现markdown编辑器效果
Oct 23 HTML / CSS
HTML+CSS制作心跳特效的实现
May 26 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文件锁函数flock()详细介绍
2014/11/18 PHP
支持中文、字母、数字的PHP验证码
2015/05/04 PHP
Yii使用migrate命令执行sql语句的方法
2016/03/15 PHP
PHP面向对象五大原则之里氏替换原则(LSP)详解
2018/04/08 PHP
PHP调用接口用post方法传送json数据的实例
2018/05/31 PHP
jquery1.4后 jqDrag 拖动 不可用
2010/02/06 Javascript
点弹代码 点击页面任何位置都可以弹出页面效果代码
2012/09/17 Javascript
jquery 清空file域示例(兼容个浏览器)
2013/10/11 Javascript
JavaScript事件委托用法分析
2015/01/24 Javascript
原生ajax处理json格式数据的实例代码
2016/12/25 Javascript
canvas实现弧形可拖动进度条效果
2017/05/11 Javascript
Angular2 自定义validators的实现方法
2017/07/05 Javascript
深入理解基于vue-cli的vuex配置
2017/07/24 Javascript
js实现图片粘贴上传到服务器并展示的实例
2017/11/08 Javascript
vue插件draggable实现拖拽移动图片顺序
2018/12/01 Javascript
PM2自动部署代码步骤流程总结
2018/12/10 Javascript
vue项目中实现的微信分享功能示例
2019/01/21 Javascript
浅谈JavaScript闭包
2019/04/09 Javascript
javascript实现手动点赞效果
2019/04/09 Javascript
解决vue打包后vendor.js文件过大问题
2019/07/03 Javascript
Python实现基于HTTP文件传输实例
2014/11/08 Python
浅谈python脚本设置运行参数的方法
2018/12/03 Python
Python定时任务随机时间执行的实现方法
2019/08/14 Python
使用opencv识别图像红色区域,并输出红色区域中心点坐标
2020/06/02 Python
详解Python调用系统命令的六种方法
2021/01/28 Python
解决pytorch 的state_dict()拷贝问题
2021/03/03 Python
利用CSS3实现单选框动画特效示例代码
2016/09/26 HTML / CSS
戴尔英国官网:Dell英国
2017/05/27 全球购物
日语翻译个人求职的自我评价
2013/10/14 职场文书
思想品德课教学反思
2014/02/10 职场文书
平安工地建设方案
2014/05/06 职场文书
倡议书格式
2014/08/30 职场文书
音乐之声音乐广播稿
2014/09/10 职场文书
2014年大学生村官工作总结
2014/11/19 职场文书
《去年的树》教学反思
2016/02/18 职场文书
SQL优化老出错,那是你没弄明白MySQL解释计划用法
2021/11/27 MySQL