国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開(kāi)發(fā) > HTML5 > 正文

html5使用html2canvas實(shí)現(xiàn)瀏覽器截圖的示例

2024-09-05 07:19:08
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

最近做項(xiàng)目為了解決全局異常信息記錄,研究了一下瀏覽器全屏截圖功能,方便用戶發(fā)現(xiàn)異常時(shí)能夠快速截圖發(fā)給管理員。最終記錄的異常信息如下,上面的【截圖報(bào)告管理員】就是使用html2canvas前端插件實(shí)現(xiàn)的。

html2canvas介紹

以前我們只能通過(guò)其他的截圖工具來(lái)截取圖像。現(xiàn)代瀏覽器的功能已經(jīng)越來(lái)越強(qiáng),隨著H5的逐漸普及,瀏覽器本身就可以截圖啦。html2canvas就是這樣一款前端插件,它的原理是將Dom節(jié)點(diǎn)在Canvas里邊畫(huà)出來(lái)。雖然很方便,但有以下限制:

  • 不支持iframe
  • 不支持跨域圖片
  • 不能在瀏覽器插件中使用
  • 部分瀏覽器上不支持SVG圖片
  • 不支持Flash
  • 不支持古代瀏覽器和IE,如果你想確認(rèn)是否支持某個(gè)瀏覽器,可以用它訪問(wèn) http://deerface.sinaapp.com/ 試試 :)

由于我的使用場(chǎng)景很簡(jiǎn)單,記錄一下異常信息,并且異常頁(yè)面也是由自己定義的,那么html2canvas 就足夠使用了。

使用實(shí)例

引用jquery,html2canvas即可,使用代碼也很簡(jiǎn)單。我這里使用的是 html2canvas 0.5.0 版本

 html2canvas($("#tbl_exception"), {         onrendered: function (canvas) {             var url = canvas.toDataURL();              //以下代碼為下載此圖片功能             var triggerDownload = $("<a>").attr("href", url).attr("download", getNowFormatDate()+"異常信息.png").appendTo("body");               triggerDownload[0].click();               triggerDownload.remove();           }   });

第一個(gè)參數(shù)是要截圖的Dom對(duì)象,第二個(gè)參數(shù)時(shí)渲染完成后回調(diào)的canvas對(duì)象。

Name Type Default Description
allowTaint boolean false Whether to allow cross-origin images to taint the canvas
background string #fff Canvas background color, if none is specified in DOM. Set undefined for transparent
height number null Define the heigt of the canvas in pixels. If null, renders with full height of the window.
letterRendering boolean false Whether to render each letter seperately. Necessary ifletter-spacing is used.
logging boolean false Whether to log events in the console.
proxy string undefined Url to the proxy which is to be used for loading cross-origin images. If left empty, cross-origin images won't be loaded.
taintTest boolean true Whether to test each image if it taints the canvas before drawing them
timeout number 0 Timeout for loading images, in milliseconds. Setting it to 0 will result in no timeout.
width number null Define the width of the canvas in pixels. If null, renders with full width of the window.
useCORS boolean false Whether to attempt to load cross-origin images as CORS served, before reverting back to proxy

問(wèn)題分析

介紹完使用之后,說(shuō)說(shuō)自己使用中遇到的問(wèn)題,截圖只能截取當(dāng)前屏幕內(nèi)的內(nèi)容。在查看插件源碼,進(jìn)行調(diào)試之后找到了解決方案。下面貼出源碼和修改后的代碼

源碼:

 return renderDocument(node.ownerDocument, options, node.ownerDocument.defaultView.innerWidth, node.ownerDocument.defaultView.innerHeight, index).then(function(canvas) {        if (typeof(options.onrendered) === "function") {            log("options.onrendered is deprecated, html2canvas returns a Promise containing the canvas");            options.onrendered(canvas);        }        return canvas;    });

修改代碼:

   //2016-02-18修改源碼,解決BUG 對(duì)于部分不能截屏不能全屏添加自定義寬高的參數(shù)以支持    var width = options.width != null ? options.width : node.ownerDocument.defaultView.innerWidth;    var height = options.height != null ? options.height : node.ownerDocument.defaultView.innerHeight;    return renderDocument(node.ownerDocument, options, width, height, index).then(function (canvas) {        if (typeof(options.onrendered) === "function") {            log("options.onrendered is deprecated, html2canvas returns a Promise containing the canvas");            options.onrendered(canvas);        }        return canvas;    });

主要是讓用戶調(diào)用時(shí)能夠自定義需要截取Dom對(duì)象的寬和高,現(xiàn)在調(diào)用方式如下

            $("#btn_screen").on("click", function () {                               html2canvas($("#tbl_exception"), {                    height: $("#tbl_exception").outerHeight() + 20,                    onrendered: function (canvas) {                        var url = canvas.toDataURL();                        //以下代碼為下載此圖片功能                        var triggerDownload = $("<a>").attr("href", url).attr("download", getNowFormatDate()+"異常信息.png").appendTo("body");                        triggerDownload[0].click();                        triggerDownload.remove();                    }                });            });

總結(jié)

通過(guò)前端插件即實(shí)現(xiàn)了瀏覽器全屏截圖功能,不得不說(shuō)H5功能越來(lái)越強(qiáng)大,以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。
 

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 鄂伦春自治旗| 平乐县| 湘阴县| 荆门市| 仙居县| 永济市| 临漳县| 大悟县| 阿瓦提县| 泸州市| 盐城市| 凤翔县| 大新县| 留坝县| 香河县| 贡山| 托克逊县| 沙洋县| 潍坊市| 新晃| 吴川市| 虹口区| 克拉玛依市| 乐陵市| 三明市| 新绛县| 胶州市| 安新县| 永福县| 钟山县| 怀柔区| 栖霞市| 公主岭市| 嘉定区| 射阳县| 金湖县| 手机| 习水县| 岳西县| 宜君县| 襄垣县|