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教程:新增加的结构伪类
Apr 02 HTML / CSS
CSS3线性渐变简单实现以及该属性在浏览器中的不同
Dec 12 HTML / CSS
细说CSS3中box属性中的overflow-x属性和overflow-y属性值的效果
Jul 21 HTML / CSS
纯css3实现走马灯效果
Dec 26 HTML / CSS
CSS3实现闪烁动画效果的方法
Feb 09 HTML / CSS
CSS+jQuery实现的在线答题功能
Apr 25 HTML / CSS
HTML5组件Canvas实现图像灰度化(步骤+实例效果)
Apr 22 HTML / CSS
html5定位并在百度地图上显示的示例
Apr 27 HTML / CSS
iphoneX 适配客户端H5页面的方法教程
Dec 08 HTML / CSS
详解html5 shiv.js和respond.min.js
Jan 24 HTML / CSS
canvas中普通动效与粒子动效的实现代码示例
Jan 03 HTML / CSS
CSS 伪元素::marker详解
Jun 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添加Xdebug扩展的方法
2014/02/12 PHP
Yii框架Session与Cookie使用方法示例
2019/10/14 PHP
非常不错的功能强大代码简单的管理菜单美化版
2008/07/09 Javascript
javascript学习基础笔记之DOM对象操作
2011/11/03 Javascript
通过js动态操作table(新增,删除相关列信息)
2012/05/23 Javascript
获得所有表单值的JQuery实现代码[IE暂不支持]
2012/05/24 Javascript
JS 实现获取打开一个界面中输入的值
2013/03/19 Javascript
上传的js验证(图片/文件的扩展名)
2013/04/25 Javascript
js数组的基本用法及数组根据下标(数值或字符)移除元素
2013/10/20 Javascript
倒记时60刷新网页的js代码
2014/02/18 Javascript
Javascript添加监听与删除监听用法详解
2014/12/19 Javascript
JS实现的简洁纵向滑动菜单(滑动门)效果
2015/10/19 Javascript
js实现四舍五入完全保留两位小数的方法
2016/08/02 Javascript
jQuery实现腾讯信用界面(自制刻度尺)样式
2017/08/15 jQuery
mpvue 单文件页面配置详解
2018/12/02 Javascript
el-input 标签中密码的显示和隐藏功能的实例代码
2019/07/19 Javascript
react quill中图片上传由默认转成base64改成上传到服务器的方法
2019/10/30 Javascript
[02:37]2015国际邀请赛选手档案—LGD.Xiao8
2015/07/28 DOTA
Python模仿POST提交HTTP数据及使用Cookie值的方法
2014/11/10 Python
pygame学习笔记(1):矩形、圆型画图实例
2015/04/15 Python
Python中字典映射类型的学习教程
2015/08/20 Python
python将unicode转为str的方法
2017/06/21 Python
python3使用pyqt5制作一个超简单浏览器的实例
2017/10/19 Python
Python cookbook(数据结构与算法)实现对不原生支持比较操作的对象排序算法示例
2018/03/15 Python
Python 查找list中的某个元素的所有的下标方法
2018/06/27 Python
Python实现的线性回归算法示例【附csv文件下载】
2018/12/29 Python
python匿名函数lambda原理及实例解析
2020/02/07 Python
如何使用pandas读取txt文件中指定的列(有无标题)
2020/03/05 Python
哪些是python中web开发框架
2020/06/17 Python
德国旅游网站:weg.de
2018/06/03 全球购物
英国著名的美容护肤和护发产品购物网站:Lookfantastic
2020/11/23 全球购物
酒店管理专业毕业生自我鉴定
2014/09/29 职场文书
学生会辞职信
2015/03/02 职场文书
元素水平垂直居中的方式
2021/03/31 HTML / CSS
python基础之匿名函数详解
2021/04/21 Python
Go结合Gin导出Mysql数据到Excel表格
2022/08/05 Golang