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过渡_动力节点Java学院整理
Jul 11 HTML / CSS
使用CSS3的背景渐变Text Gradient 创建文字颜色渐变
Aug 19 HTML / CSS
利用CSS3实现文本框的清除按钮相关的一些效果
Jun 23 HTML / CSS
CSS3实现瀑布流布局与无限加载图片相册的实例代码
Dec 22 HTML / CSS
HTML5中drawImage用法分析
Dec 01 HTML / CSS
HTML5 Canvas基本线条绘制的实例教程
Mar 17 HTML / CSS
HTML5移动端开发中的Viewport标签及相关CSS用法解析
Apr 15 HTML / CSS
有关HTML5页面在iPhoneX适配问题
Nov 13 HTML / CSS
使用canvas对多图片拼合并导出图片的方法
Aug 28 HTML / CSS
Html5页面获取微信公众号的openid的方法
May 12 HTML / CSS
HTML5 video循环播放多个视频的方法步骤
Aug 06 HTML / CSS
CSS三大特性继承性、层叠性和优先级详解
Jan 18 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执行批量mysql语句的解决方法
2013/05/02 PHP
php pki加密技术(openssl)详解
2013/07/01 PHP
PHP命名空间(namespace)的动态访问及使用技巧
2014/08/18 PHP
使用新浪微博API的OAuth认证发布微博实例
2015/03/27 PHP
curl 出现错误的调试方法(必看)
2017/02/13 PHP
PHP切割汉字的常用方法实例总结
2019/04/27 PHP
基于PHP实现用户在线状态检测
2020/11/10 PHP
javascript div 弹出可拖动窗口
2009/02/26 Javascript
JQuery jsonp 使用示例代码
2009/08/12 Javascript
JavaScript面向对象设计二 构造函数模式
2011/12/20 Javascript
jQuery实现拖动调整表格单元格大小的代码实例
2015/01/13 Javascript
提升jQuery的性能需要做好七件事
2016/01/11 Javascript
BootStrapValidator初使用教程详解
2017/02/10 Javascript
Angular 4.x 动态创建表单实例
2017/04/25 Javascript
微信小程序之获取当前位置经纬度以及地图显示详解
2017/05/09 Javascript
微信小程序实现的自定义分享功能示例
2019/02/12 Javascript
Vue 动态路由的实现及 Springsecurity 按钮级别的权限控制
2019/09/05 Javascript
详解vue-template-admin三级路由无法缓存的解决方案
2020/03/10 Javascript
移动端JS实现拖拽两种方法解析
2020/10/12 Javascript
jQuery实现推拉门效果
2020/10/19 jQuery
python实现斐波那契递归函数的方法
2014/09/08 Python
Python中使用Queue和Condition进行线程同步的方法
2016/01/19 Python
Python中常见的异常总结
2018/02/20 Python
Python实现 PS 图像调整中的亮度调整
2019/06/28 Python
Python 分享10个PyCharm技巧
2019/07/13 Python
python实现批量文件重命名
2019/10/31 Python
Python实现爬取网页中动态加载的数据
2020/08/17 Python
科颜氏美国官网:Kiehl’s美国
2017/01/31 全球购物
Chemist Warehouse中文网:澳洲连锁大药房
2021/02/05 全球购物
delegate与普通函数的区别
2014/01/22 面试题
廉洁自律承诺书
2014/03/27 职场文书
2014年征兵标语
2014/06/20 职场文书
2014年行政部工作总结
2014/11/19 职场文书
2015新学期家长寄语
2015/02/26 职场文书
原生CSS实现文字无限轮播的通用方法
2021/03/30 HTML / CSS
德劲DE1102数字调谐收音机机评
2022/04/07 无线电