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 渐变(Gradients)之CSS3 径向渐变
Jul 08 HTML / CSS
css3实现可滑动跳转的分页插件示例
May 08 HTML / CSS
图解CSS3制作圆环形进度条的实例教程
May 26 HTML / CSS
CSS3中的display:grid,网格布局介绍
Oct 30 HTML / CSS
css3实现背景动态渐变效果
Dec 10 HTML / CSS
使用HTML5 Canvas绘制直线或折线等线条的方法讲解
Mar 14 HTML / CSS
用html5的canvas画布绘制贝塞尔曲线完整代码
Aug 14 HTML / CSS
让IE下支持Html5的placeholder属性的插件
Sep 02 HTML / CSS
详解html5 canvas 微信海报分享(个人爬坑)
Jan 12 HTML / CSS
HTML5自定义属性的问题分析
Aug 16 HTML / CSS
Html5实现首页动态视频背景的示例代码
Sep 25 HTML / CSS
浅谈css实现背景颜色半透明的两种方法
Dec 06 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
杏林同学录(六)
2006/10/09 PHP
PHP安全技术之 实现php基本安全
2010/09/04 PHP
在PHP中使用curl_init函数的说明
2010/11/02 PHP
php函数与传递参数实例分析
2014/11/15 PHP
php使用gzip压缩传输js和css文件的方法
2015/07/29 PHP
php防止用户重复提交表单
2015/11/02 PHP
PHP htmlspecialchars()函数用法与实例讲解
2019/03/08 PHP
php面试实现反射注入的详细方法
2019/09/30 PHP
FusionCharts图表显示双Y轴双(多)曲线
2012/11/22 Javascript
jquery实现在页面加载完毕后获取图片高度或宽度
2014/06/16 Javascript
JS实现仿QQ聊天窗口抖动特效
2015/05/10 Javascript
IE7浏览器窗口大小改变事件执行多次bug及IE6/IE7/IE8下resize问题
2015/08/21 Javascript
基于Node.js的JavaScript项目构建工具gulp的使用教程
2016/05/20 Javascript
JavaScript表单验证开发
2016/11/23 Javascript
js正则表达式验证密码强度【推荐】
2017/03/03 Javascript
微信小程序开发实现的IP地址查询功能示例
2019/03/28 Javascript
vue实现前端分页完整代码
2020/06/17 Javascript
浅谈使用nodejs搭建web服务器的过程
2020/07/20 NodeJs
结合axios对项目中的api请求进行封装操作
2020/09/21 Javascript
原生JS运动实现轮播图
2021/01/02 Javascript
Vue常用API、高级API的相关总结
2021/02/02 Vue.js
python计算圆周长、面积、球体体积并画出圆
2014/04/08 Python
python使用urllib2实现发送带cookie的请求
2015/04/28 Python
python中使用iterrows()对dataframe进行遍历的实例
2018/06/09 Python
python操作kafka实践的示例代码
2019/06/19 Python
python射线法判断检测点是否位于区域外接矩形内
2019/06/28 Python
keras tensorflow 实现在python下多进程运行
2020/02/06 Python
德国的各种媒体在线商店:Thalia.de(书籍、电子书、玩具等)
2020/10/08 全球购物
青春奉献演讲稿
2014/05/08 职场文书
2014年党支部学习材料
2014/05/19 职场文书
活动费用申请报告
2015/05/15 职场文书
二审答辩状范文
2015/05/22 职场文书
城南旧事电影观后感
2015/06/16 职场文书
幼儿园托班开学寄语(2016秋季)
2015/12/03 职场文书
Golang之sync.Pool使用详解
2021/05/06 Golang
《辉夜大小姐想让我告白》第三季正式预告
2022/03/20 日漫