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 相关文章推荐
纯CSS实现聊天框小尖角、气泡效果
Apr 04 HTML / CSS
详解CSS3中Media Queries的相关使用
Jul 17 HTML / CSS
canvas之万花筒效果的简单实现(推荐)
Aug 16 HTML / CSS
html5的新增的标签和废除的标签简要概述
Feb 20 HTML / CSS
HTML5 video 事件应用示例
Sep 11 HTML / CSS
详解HTML5中的Communication API基本使用方法
Jan 29 HTML / CSS
iphoneX 适配客户端H5页面的方法教程
Dec 08 HTML / CSS
Html5调用手机摄像头并实现人脸识别的实现
Dec 21 HTML / CSS
html5 制作地图当前定位箭头的方法示例
Jan 10 HTML / CSS
uniapp+Html5端实现PC端适配
Jul 15 HTML / CSS
HTML5基础学习之文本标签控制
Mar 25 HTML / CSS
常用的文件对应的MIME类型汇总
Apr 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
用Socket发送电子邮件
2006/10/09 PHP
基于PHP文件操作的详细诠释
2013/06/21 PHP
Dwz与thinkphp整合下的数据导出到Excel实例
2014/12/04 PHP
Laravel中注册Facades的步骤详解
2016/03/16 PHP
JS实现QQ图片一闪一闪的效果小例子
2013/07/31 Javascript
jquery结合CSS使用validate实现漂亮的验证
2015/01/29 Javascript
jquery实现鼠标滑过显示提示框的方法
2015/02/05 Javascript
jQuery插件Validate实现自定义校验结果样式
2016/01/18 Javascript
浅析javascript函数表达式
2016/02/10 Javascript
Html5+jQuery+CSS制作相册小记录
2016/12/30 Javascript
JavaScript Canvas绘制圆形时钟效果
2020/08/20 Javascript
Angular实现图片裁剪工具ngImgCrop实践
2017/08/17 Javascript
简单实现jQuery手风琴效果
2017/08/18 jQuery
利用vue + element实现表格分页和前端搜索的方法
2017/12/25 Javascript
jQuery实现的网站banner图片无缝轮播效果完整实例
2019/01/28 jQuery
针对Vue路由history模式下Nginx后台配置操作
2020/10/22 Javascript
JS中循环遍历数组的四种方式总结
2021/01/23 Javascript
[01:24]2014DOTA2 TI第二日 YYF表示这届谁赢都有可能
2014/07/11 DOTA
使用Python的Bottle框架写一个简单的服务接口的示例
2015/08/25 Python
Flask框架的学习指南之制作简单blog系统
2016/11/20 Python
django连接mysql配置方法总结(推荐)
2018/08/18 Python
对Python 多线程统计所有csv文件的行数方法详解
2019/02/12 Python
在Python函数中输入任意数量参数的实例
2019/07/16 Python
Python搭建代理IP池实现检测IP的方法
2019/10/27 Python
Python动态强类型解释型语言原理解析
2020/03/25 Python
Python获取浏览器窗口句柄过程解析
2020/07/25 Python
Brydge英国:适用于Apple iPad和Microsoft Surface Pro的蓝牙键盘
2019/05/16 全球购物
澳大利亚在线高跟鞋商店:Shoe Me
2019/11/19 全球购物
统计系教授推荐信
2014/02/28 职场文书
大气污染防治方案
2014/05/19 职场文书
教师听课评语大全
2014/12/31 职场文书
大三学生英语考试作弊检讨书
2015/01/01 职场文书
写给医生的感谢信
2015/01/22 职场文书
有关花店创业的计划书模板
2019/08/27 职场文书
MySQL 重写查询语句的三种策略
2021/05/10 MySQL
Redis实现一个账号只能登录一个设备
2022/04/19 Redis