Implementation code for taking screenshots using HTML and saving them as local images

Implementation code for taking screenshots using HTML and saving them as local images

The specific code is as follows:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>html2canvas_download</title>
        <style>
            a {
                cursor: pointer;
                color: rgb(85, 26, 139);
                text-decoration: underline;
            }
        </style>
    </head>
    <body>
        <div id="oDiv" style="width: 300px; height: 300px; margin: 10px; background: red; border: 5px solid gray;">
            <h1>hello world!</h1>
        </div>
        <!-- <script type="text/javascript" src="../dist/html2canvas.js"></script> -->
        <script src="https://cdn.bootcss.com/html2canvas/0.5.0-beta4/html2canvas.min.js"></script>
        <script type="text/javascript">
            var oDiv = document.getElementById('oDiv');
            //body screenshot//html2canvas(document.body).then(function(canvas) {
            // document.body.appendChild(canvas);
            // });
            html2canvas(oDiv).then(function(canvas) {
                document.body.appendChild(canvas);
                var oCavans = document.getElementsByTagName('canvas')[0];
                var strDataURI = oCavans.toDataURL();
                downLoadFn(strDataURI);
            });
            //Determine the browser type function myBrowser() {
                var userAgent = navigator.userAgent; //Get the browser's userAgent string var isOpera = userAgent.indexOf("Opera") > -1;
                if(isOpera) {
                    return "Opera"
                }; //Judge whether it is Opera browser if(userAgent.indexOf("Firefox") > -1) {
                    return "FF";
                } //Judge whether it is Firefox browser if(userAgent.indexOf("Chrome") > -1) {
                    return "Chrome";
                }
                if (userAgent.indexOf("Safari") > -1) {
                    return "Safari";
                } // Determine whether it is Safari browser if (userAgent.indexOf("compatible") > -1 && userAgent.indexOf("MSIE") > -1 && !isOpera) {
                    return "IE";
                }; //Judge whether it is IE browser if(userAgent.indexOf("Trident") > -1) {
                    return "Edge";
                } //Determine whether it is Edge browser}
            //IE browser saves the picture locally function SaveAs5(imgURL) {
                var oPop = window.open(imgURL, "", "width=1, height=1, top=5000, left=5000");
                for(; oPop.document.readyState != "complete";) {
                    if(oPop.document.readyState == "complete") break;
                }
                oPop.document.execCommand("SaveAs");
                oPop.close();
            }
            // chrome14+,firefox20+,pera15+,Edge 13+,Safari do not implement function download(strDataURI) {
                var link = document.createElement('a');
                link.innerHTML = 'download_canvas_image';
                link.download = 'mypainting.png';
                link.addEventListener('click', function(ev) {
                    link.href = strDataURI;
                }, false);
                document.body.appendChild(link);
            };
            function downLoadFn(url) {
                if(myBrowser() === "IE" || myBrowser() === "Edge") {
                    SaveAs5(url);
                } else {
                    download(url);
                }
            }
        </script>
    </body>
</html>

Summarize

The above is the implementation code that I introduced to you for using HTML screenshots and saving them as local images. I hope it will be helpful to you. If you have any questions, please leave me a message and I will reply to you in time. I would also like to thank everyone for their support of the 123WORDPRESS.COM website!

<<:  Install MySQL5.5 database in CentOS7 environment

>>:  Sample code of uniapp vue and nvue carousel components

Recommend

How to install PHP7.4 and Nginx on Centos

Prepare 1. Download the required installation pac...

HTML Tutorial: Collection of commonly used HTML tags (6)

These introduced HTML tags do not necessarily ful...

Implementation of nested jump of vue routing view router-view

Table of contents 1. Modify the app.vue page 2. C...

MySQL 8.0.22 winx64 installation and configuration graphic tutorial

mysql 8.0.22 winx64 installation and configuratio...

Mysql optimization Zabbix partition optimization

The biggest bottleneck of using zabbix is ​​the d...

How to optimize a website to increase access speed update

Recently, the company has begun to evaluate all s...

Solution to web page confusion caused by web page FOUC problem

FOUC is Flash of Unstyled Content, abbreviated as ...

Vue implements carousel animation

This article example shares the specific code of ...

Detailed explanation of the usage of grep command in Linux

1. Official Introduction grep is a commonly used ...

CSS implements the bottom tapbar function

Now many mobile phones have the function of switc...

MySQL Series II Multi-Instance Configuration

Tutorial Series MySQL series: Basic concepts of M...

Summary of knowledge points about null in MySQL database

In the MySQL database, null is a common situation...

Nodejs error handling process record

This article takes the connection error ECONNREFU...

Detailed explanation of the construction and use of Docker private warehouse

The image can be saved on hub.docker.com, but the...