🌓
搜索
 找回密码
 立即注册

干货分享--html2canvas页面截图神器

html5的那些破事 2018-3-22 00:06:04 86054

页面截图神器html2canvas,html2canvas是一个相当不错的JavaScript类库,它使用了html5和css3的一些新功能特性,实现了在客户端对网页进行截图的功 能。html2canvas通过获取页面的DOM和元素的样式信息,并将其渲染成canvas图片,从而实现给页面截图的功能。

它不需要来自服务器任何渲染,整张图片都是在客户端浏览器创建。当浏览器不支持Canvas时,将采用Flashcanvas或ExplorerCanvas技术代替实现。以下浏览器能够很好的支持该脚本:Firefox 3.5+, Google Chrome,Opera新的版本, IE9以上的浏览器。


因为每个浏览器渲染页面的方式都不尽相同,所以生成的图片也不太一样。虽然它目前还是处理开发阶段,但还是很值得期待的。 

面来介绍下页面截图神器html2canvas的使用方法:

    这个插件依赖于jQuery插件,建议使用最新版的。
兼容性
html2canvas能在以下的浏览器中完美的运行。

- Firefox 3.5+
- Chrome
- Opera
- IE9使用方法

1、引入文件

首先我们需要引入jQuery库和html2canvas插件文件,注意html2canvas插件文件一定要在jQuery的后面引入,不然会报错。
<script type="text/javascript"
src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
<script type="text/javascript"
src="http://html2canvas.hertzen.com/build/html2canvas.js"></script>
2、调用插件

通过html2canvas方法调用插件,该方法接受两个参数,第一个为要生成截图的DOM元素,第二个参数为插件的配置
html2canvas(document.body, { allowTaint: true, taintTest: false,
onrendered: function(canvas) { canvas.id = "mycanvas";
//document.body.appendChild(canvas); //生成base64图片数据 var dataUrl =
canvas.toDataURL(); var newImg = document.createElement("img);
newImg.src = dataUrl; document.body.appendChild(newImg); } });
通过一个回调函数来处理获取到的截图。
图片跨域问题
在网页的图片中,如果有跨域图片,调用toDataURL的时候会出错
SecurityError: The operation is insecure.
解决方法是在跨域的服务器上设置header设置为允许跨域请求
access-control-allow-origin: *  access-control-allow-credentials: true
官网主页: http://html2canvas.hertzen.com/


想了解更多干货,赶紧来关注 html5的那些破事  每周还有不定时的红包活动,赶紧来关注吧!希望小编做的点滴分享能够陪伴您的成长,谢谢您的阅读`(*∩_∩*)′


扫一扫

59156.jpg
随机推荐

最新主题

0 回复

高级模式
游客
返回顶部