请问浏览器如何截屏?

发布网友 发布时间:2022-04-23 15:36

我来回答

3个回答

懂视网 时间:2022-05-12 17:39

这篇文章主要介绍了html5使用html2canvas实现浏览器截图的示例,非常具有实用价值,需要的朋友可以参考下

最近做项目为了解决全局异常信息记录,研究了一下浏览器全屏截图功能,方便用户发现异常时能够快速截图发给管理员。最终记录的异常信息如下,上面的【截图报告管理员】就是使用html2canvas前端插件实现的。

html2canvas介绍

以前我们只能通过其他的截图工具来截取图像。现代浏览器的功能已经越来越强,随着H5的逐渐普及,浏览器本身就可以截图啦。html2canvas就是这样一款前端插件,它的原理是将Dom节点在Canvas里边画出来。虽然很方便,但有以下:

  • 不支持iframe

  • 不支持跨域图片

  • 不能在浏览器插件中使用

  • 部分浏览器上不支持SVG图片

  • 不支持Flash

  • 不支持古代浏览器和IE,如果你想确认是否支持某个浏览器,可以用它访问 http://deerface.sinaapp.com/ 试试 :)

  • 由于我的使用场景很简单,记录一下异常信息,并且异常页面也是由自己定义的,那么html2canvas 就足够使用了。

    使用实例

    引用jquery,html2canvas即可,使用代码也很简单。我这里使用的是 html2canvas 0.5.0 版本


    第一个参数是要截图的Dom对象,第二个参数时渲染完成后回调的canvas对象。

    NameTypeDefaultDescription
    allowTaintbooleanfalseWhether to allow cross-origin images to taint the canvas
    backgroundstring#fffCanvas background color, if none is specified in DOM. Set undefined for transparent
    heightnumbernullDefine the heigt of the canvas in pixels. If null, renders with full height of the window.
    letterRenderingbooleanfalseWhether to render each letter seperately. Necessary ifletter-spacing is used.
    loggingbooleanfalseWhether to log events in the console.
    proxystringundefinedUrl to the proxy which is to be used for loading cross-origin images. If left empty, cross-origin images won't be loaded.
    taintTestbooleantrueWhether to test each image if it taints the canvas before drawing them
    timeoutnumber0Timeout for loading images, in milliseconds. Setting it to 0 will result in no timeout.
    widthnumbernullDefine the width of the canvas in pixels. If null, renders with full width of the window.
    useCORSbooleanfalseWhether to attempt to load cross-origin images as CORS served, before reverting back to proxy

    问题分析

    介绍完使用之后,说说自己使用中遇到的问题,截图只能截取当前屏幕内的内容。在查看插件源码,进行调试之后找到了解决方案。下面贴出源码和修改后的代码

    源码:


    修改代码:


    主要是让用户调用时能够自定义需要截取Dom对象的宽和高,现在调用方式如下


    热心网友 时间:2022-05-12 14:47

    直接使用键盘中的Print Scr Sysrq键实现全屏截图,除此之外您还可以通过QQ或者其他工具进行截图。

    希望能够帮到您,感谢进的采纳!

    热心网友 时间:2022-05-12 16:05

    只需要按住ALT+A就行了。

    声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com