html2canvas截图空白问题的解决


Posted in HTML / CSS onMarch 24, 2020

最近在项目中遇到一个需求,需要提供网页截图的功能。百度下发现html2canvas很好用。那就试试吧。

资源下载地址

插件下载地址:html2canvas下载地址

使用方式

项目使用的react组件开发方式。参照官方的说明文档getting-started.md,按照以下步骤进行:

1、使用以下命令安装

npm install html2canvas --save

2、在文件中引入html2canvas

import html2canvas from 'html2canvas';

3、文件中的使用

html2canvas(document.body).then(function(canvas) {
document.body.appendChild(canvas);
});

遇到的问题

按照这个方式使用,页面没有滚动条还行,有滚动条时出现大片空白。

错误截图如下:

html2canvas截图空白问题的解决

解决方案

仔细看了一下configuration.md和网友的分析,最终解决。代码片段如下

html2canvas截图空白问题的解决

上一张正确的截图如下:

html2canvas截图空白问题的解决

代码中的配置项说明

1、截图产生空白是因为容器高度设置的问题,设置windowHeight的高度等于页面包含滚动条的高度即可获取滚动条中的内容。这一条就可以解决空白的问题。
2、设置width、height属性的原因是,我们在页面中截图显示的区域宽度和高度是固定的,就是当前屏幕的可见区域。
3、设置x、y坐标的原因是由于页面在有滚动条的时候,需要指定截图的起始位置。本项目中x轴方向不存在滚动条,所以设置为零;y方向有滚动条,所以需要获取一下当前方向的滚动坐标。
4、一般网页中会有图片,图片中有链接地址时,设置useCORS属性可保证图片的加载。

到此这篇关于html2canvas截图空白问题的解决的文章就介绍到这了,更多相关html2canvas截图空白内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
CSS3实现任意图片lowpoly动画效果实例
May 11 HTML / CSS
基于CSS3实现的漂亮Menu菜单效果代码
Sep 10 HTML / CSS
CSS3 毛玻璃效果
Aug 14 HTML / CSS
CSS3 实现的加载动画
Dec 07 HTML / CSS
html5 input属性使用示例
Jun 28 HTML / CSS
浅谈基于HTML5的在线视频播放方案
Feb 18 HTML / CSS
跨域修改iframe页面内容详解
Oct 31 HTML / CSS
解决HTML5中的audio在手机端和微信端的不能自动播放问题
Nov 04 HTML / CSS
网站性能延迟加载图像的五种技巧(小结)
Aug 13 HTML / CSS
Html5页面播放M4a音频文件
Mar 30 HTML / CSS
HTML5来实现本地文件读取和写入的实现方法
May 25 HTML / CSS
CSS的calc函数用法小结
Jun 25 HTML / CSS
html5视频常用API接口的实战示例
Mar 20 #HTML / CSS
Html5页面上如何禁止手机虚拟键盘弹出
Mar 19 #HTML / CSS
Html5 Canvas实现图片标记、缩放、移动和保存历史状态功能 (附转换公式)
Mar 18 #HTML / CSS
Html+Css+Jquery实现左侧滑动拉伸导航菜单栏的示例代码
Mar 17 #HTML / CSS
canvas实现手机的手势解锁的步骤详细
Mar 16 #HTML / CSS
HTML利用九宫格原理进行网页布局
Mar 13 #HTML / CSS
html5默认气泡修改的代码详解
Mar 13 #HTML / CSS
You might like
PHP 在5.1.* 和5.2.*之间 PDO数据库操作中的不同之处小结
2012/03/07 PHP
Linux中用PHP判断程序运行状态的2个方法
2014/05/04 PHP
php隐藏IP地址后两位显示为星号的方法
2014/11/21 PHP
php的crc32函数使用时需要注意的问题(不然就是坑)
2015/04/21 PHP
Zend Framework教程之连接数据库并执行增删查的方法(附demo源码下载)
2016/03/21 PHP
wordpress自定义标签云与随机获取标签的方法详解
2019/03/22 PHP
javascript 延迟加载技术(lazyload)简单实现
2011/01/17 Javascript
表单JS弹出填写提示效果代码
2011/04/16 Javascript
JavaScript高级程序设计(第3版)学习笔记5 js语句
2012/10/11 Javascript
Js 获取Gridview选中行的内容操作步骤
2013/02/05 Javascript
js css 实现遮罩层覆盖其他页面元素附图
2014/09/22 Javascript
jQuery获取父元素及父节点的方法小结
2016/04/14 Javascript
jQuery简单注册和禁用全局事件的方法
2016/07/25 Javascript
使用gulp搭建本地服务器并实现模拟ajax
2017/04/05 Javascript
jQuery实现可编辑表格并生成json结果(实例代码)
2017/07/19 jQuery
vue-cli之router基本使用方法详解
2017/10/17 Javascript
[15:20]DOTA2亚洲邀请赛总决赛开幕式表演:羽泉献唱
2017/04/05 DOTA
[01:13:08]2018DOTA2亚洲邀请赛4.6 淘汰赛 mineski vs LGD 第二场
2018/04/10 DOTA
python使用xmlrpclib模块实现对百度google的ping功能
2015/06/02 Python
Python中Class类用法实例分析
2015/11/12 Python
python中 chr unichr ord函数的实例详解
2017/08/06 Python
python下实现二叉堆以及堆排序的示例
2017/09/29 Python
Python实现将HTML转换成doc格式文件的方法示例
2017/11/20 Python
TensorFlow 实战之实现卷积神经网络的实例讲解
2018/02/26 Python
使用pycharm和pylint检查python代码规范操作
2020/06/09 Python
浅谈CSS3鼠标移入图片动态提示效果(transform)
2017/11/06 HTML / CSS
html5中的一些标签学习(心得)
2016/10/18 HTML / CSS
英国汽车座椅和婴儿车购物网站:Uber Kids
2017/04/19 全球购物
德国柯吉澳趣味家居:Koziol
2017/08/24 全球购物
马来西亚在线购物市场:PGMall.my
2019/10/13 全球购物
应届生法律求职信
2013/10/22 职场文书
党委书记个人检查对照材料思想汇报
2014/10/11 职场文书
商场广播稿范文
2015/08/19 职场文书
Vue CLI中模式与环境变量的深入详解
2021/05/30 Vue.js
解析redis hash应用场景和常用命令
2021/08/04 Redis
浅谈JavaScript浅拷贝和深拷贝
2021/11/07 Javascript