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属性background-size使用指南
Dec 09 HTML / CSS
浅谈CSS3动画的回调处理
Jul 21 HTML / CSS
详解CSS3中强大的filter(滤镜)属性
Jun 29 HTML / CSS
HTML5视频支持检测(检查浏览器是否支持视频播放)
Jun 08 HTML / CSS
浅析border-radius如何兼容IE
Apr 19 HTML / CSS
html5的input的required使用中遇到的问题及解决方法
Apr 24 HTML / CSS
详解window.open被浏览器拦截的解决方案
Jul 18 HTML / CSS
HTML速写之Emmet语法规则的实现
Apr 07 HTML / CSS
HTML5简单实现添加背景音乐的几种方法
May 12 HTML / CSS
HTML5页面音频自动播放的实现方式
Jun 21 HTML / CSS
html form表单基础入门案例讲解
Jul 21 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
手冲咖啡应该是现代精品咖啡店的必备选项吗?
2021/03/03 冲泡冲煮
PHP setcookie() cannot modify header information 的解决方法
2009/01/09 PHP
php学习笔记 数组的常用函数
2011/06/13 PHP
php数组函数序列之array_search()- 按元素值返回键名
2011/11/04 PHP
PHP中empty,isset,is_null用法和区别
2017/02/19 PHP
Mozilla 表达式 __noSuchMethod__
2009/04/05 Javascript
jQuery dialog 异步调用ashx,webservice数据的代码
2010/08/03 Javascript
jQuery LigerUI 插件介绍及使用之ligerDrag和ligerResizable示例代码打包
2011/04/06 Javascript
javascript编码的几个方法详细介绍
2013/01/06 Javascript
javascript中的toFixed固定小数位数 简单实例分享
2013/07/12 Javascript
浅析JavaScript中的常用算法与函数
2013/11/21 Javascript
jquery 隐藏与显示tr标签示例代码
2014/06/06 Javascript
jQuery实现点击任意位置弹出层外关闭弹出层效果
2016/10/19 Javascript
jQuery post数据至ashx实例详解
2016/11/18 Javascript
深入理解Javascript中的作用域链和闭包
2017/04/25 Javascript
jQuery实现的简单图片轮播效果完整示例
2018/02/08 jQuery
jQuery仿移动端支付宝键盘的实现代码
2018/08/15 jQuery
详解angular2如何手动点击特定元素上的点击事件
2018/10/16 Javascript
vue实现微信二次分享以及自定义分享的示例
2019/03/20 Javascript
微信小程序 wxParse插件显示视频问题
2019/09/27 Javascript
jstree中的checkbox默认选中和隐藏示例代码
2019/12/29 Javascript
原生js实现五子棋游戏
2020/05/28 Javascript
Vue实现简单计算器
2021/01/20 Vue.js
python thread 并发且顺序运行示例
2009/04/09 Python
Django中几种重定向方法
2015/04/28 Python
人生苦短我用python python如何快速入门?
2018/03/12 Python
Python3 Post登录并且保存cookie登录其他页面的方法
2018/12/28 Python
详解Python locals()的陷阱
2019/03/26 Python
Python cookie的保存与读取、SSL讲解
2020/02/17 Python
pycharm工具连接mysql数据库失败问题
2020/04/01 Python
Lampenwelt德国:欧洲领先的灯具和照明在线商店
2018/08/05 全球购物
毕业生应聘幼儿园的自荐信
2013/11/20 职场文书
大型主题婚礼活动策划方案
2014/09/15 职场文书
机电专业毕业生自我鉴定2014
2014/10/04 职场文书
超越Nginx的Web服务器caddy优雅用法
2022/06/21 Servers
win10如何快速切换窗口 win10切换窗口快捷键分享
2022/07/23 数码科技