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新增颜色表示方式分享
Apr 15 HTML / CSS
CSS3中box-shadow的用法介绍
Jul 15 HTML / CSS
CSS3动画:5种预载动画效果实例
Apr 05 HTML / CSS
CSS3中的display:grid,网格布局介绍
Oct 30 HTML / CSS
HTML5 Convas APIs方法详解
Apr 24 HTML / CSS
HTML5标签使用方法详解
Nov 27 HTML / CSS
基于HTML5陀螺仪实现ofo首页眼睛移动效果的示例
Jul 31 HTML / CSS
html5中canvas图表实现柱状图的示例
Nov 13 HTML / CSS
HTML5 canvas 瀑布流文字效果的示例代码
Jan 31 HTML / CSS
canvas进阶之如何画出平滑的曲线
Oct 15 HTML / CSS
原生 JS+CSS+HTML 实现时序图的方法
Jul 31 HTML / CSS
html+css实现环绕倒影加载特效
Jul 07 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
Netflix将与CLAMP、乙一以及冲方丁等6名知名制作人合伙展开原创动画计划!
2020/03/06 日漫
PHP Memcached + APC + 文件缓存封装实现代码
2010/03/11 PHP
PHP使用preg_split()分割特殊字符(元字符等)的方法分析
2017/02/04 PHP
thinkPHP5.0框架开发规范简介
2017/03/25 PHP
iis 7下安装laravel 5.4环境的方法教程
2017/06/14 PHP
php实现socket推送技术的示例
2017/12/20 PHP
php 读写json文件及修改json的方法
2018/03/07 PHP
php代码调试利器firephp安装与使用方法分析
2018/08/21 PHP
Yii框架响应组件用法实例分析
2019/09/04 PHP
JavaScript 全面解析各种浏览器网页中的JS 执行顺序
2009/02/17 Javascript
js循环改变div颜色具体方法
2013/06/25 Javascript
百度地图自定义控件分享
2015/03/04 Javascript
IE浏览器下PNG相关功能
2015/07/05 Javascript
Spring mvc 接收json对象
2015/12/10 Javascript
JS关闭窗口时产生的事件及用法示例
2016/08/20 Javascript
Ionic默认的Tabs模板使用实例
2016/08/29 Javascript
JavaScript递归算法生成树形菜单
2017/08/15 Javascript
vue生成随机验证码的示例代码
2017/09/29 Javascript
webuploader分片上传的实现代码(前后端分离)
2018/09/10 Javascript
js实现内置计时器
2019/12/16 Javascript
JQuery表单元素取值赋值方法总结
2020/05/12 jQuery
Python语言的12个基础知识点小结
2014/07/10 Python
Python中的复制操作及copy模块中的浅拷贝与深拷贝方法
2016/07/02 Python
python查看文件大小和文件夹内容的方法
2019/07/08 Python
python 判断字符串中是否含有汉字或非汉字的实例
2019/07/15 Python
python切片(获取一个子列表(数组))详解
2019/08/09 Python
20行Python代码实现视频字符化功能
2020/04/13 Python
Python + opencv对拍照得到的图片进行背景去除的实现方法
2020/11/18 Python
CSS3实现翘边的阴影效果的代码示例
2016/06/13 HTML / CSS
图库照片、免版税图片、矢量艺术、视频片段:Depositphotos
2019/08/02 全球购物
管理建议书范文
2014/05/13 职场文书
人力资源管理系自荐信
2014/05/31 职场文书
银行稽核岗位职责
2015/04/13 职场文书
2019年幼儿园家长接送责任书
2019/10/29 职场文书
Spring Data JPA框架的核心概念和Repository接口
2022/04/28 Java/Android
java实现自定义时钟并实现走时功能
2022/06/21 Java/Android