html2canvas截取页面

简介:

1.下载html2canvas.js

2.引入

3.修改html2canvas支持远程图片处理

function ImageContainer(src, cors) {
        this.src = src;
        this.image = new Image();
        var self = this;
        this.tainted = null;
        this.promise = new Promise(function(resolve, reject) {
            self.image.onload = resolve;
            self.image.onerror = reject;
            if (cors) {
                //self.image.crossOrigin = "anonymous";//1.去掉此处的anonymous代码改为空
                self.image.crossOrigin = "";
            }
            //self.image.src = src;//2.在源src后面添加一个随机数如时间戳+"?"+new Date().getTime();
            self.image.src = src+"?"+new Date().getTime();
            if (self.image.complete === true) {
                resolve(self.image);
            }
        });
    }

4.保存成base64,并处理

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="utf-8">
    <meta name="viewport"
          content="maximum-scale=1.0,minimum-scale=1.0,user-scalable=0,width=device-width,initial-scale=1.0"/>
    <meta name="format-detection" content="telephone=no,email=no,date=no,address=no">
    <title>群二维码名片</title>
    <link rel="stylesheet" href="../css/aui.2.0.css">
    <link rel="stylesheet" href="../css/message_style.css">
</head>
<body>

<header class="aui-bar aui-bar-nav aui-margin-b-15">
    <a class="aui-pull-left aui-btn" onclick="closeWin();">
        <span class="aui-iconfont aui-icon-left">返回</span>
    </a>
    <div class="aui-title">群二维码</div>
</header>

<div id="info_area"></div>

<script id="info_tmpl" type="text/html/x-dot-template">
<div class="s_cardbg">
    <div class="s_card" id="qrcode_card">
        <header>
            <img src="{{= it.groupAvatar}}"/>
            <span>{{= it.groupName}}</span>
        </header>
        <img id="qrcode_img" src="{{= it.qrcode}}" class="s_code"/>
    </div>
</div>
<div class="s_carbtnbg">
    <div class="s_caranimation">
        <button id="save">保存图片</button>
        <button class="s_sarcancel">取消</button>
    </div>
</div>
</script>
</body>
<script type="text/javascript" src="../script/api.js"></script>
<script type="text/javascript"  src="../script/jquery.min.js"></script>
<script type="text/javascript" src="../script/config.js"></script>
<script type="text/javascript" src="../script/common.js"></script>
<script type="text/javascript" src="../script/doT.min.js"></script>
<script type="text/javascript" src="../script/html2canvas.js"></script>

<script>
    apiready = function () {
        fix_status_bar();
        var groupId = api.pageParam.groupId;
        var groupName = api.pageParam.groupName;
        var groupAvatar = api.pageParam.groupAvatar;
        var qrcode  = BASE_URL_ACTION + '/Common/GetQrCode?dataId='+groupId+'&dataType=2&prefix=add';

        var data = {};
        data.groupId = groupId;
        data.groupName = groupName;
        data.groupAvatar = groupAvatar;
        data.qrcode = qrcode;
        var interText = doT.template($("#info_tmpl").text());
        $("#info_area").html(interText(data));

        $(".s_code").on("touchstart",function(){
            $(".s_carbtnbg").show();
        })
        $(".s_sarcancel").on("click",function(){
            $(".s_carbtnbg").hide()
        })

        $("#save").on("click", function () {
            html2canvas($("#qrcode_card"), {
                height: $("#qrcode_card").outerHeight() + 20,
                onrendered: function (canvas) {
                    var url = canvas.toDataURL("image/png");
                    var base64str = url.substr(22);
                    //以下代码为下载此图片功能
                    //                    $("#qrcode_img").attr('src',url);

                    var trans = api.require('trans');
                    trans.saveImage({
                        base64Str : base64str,
                        album : true,
                        imgPath : "fs://"
                    }, function(ret, err) {
                        if (ret.status) {
                            toast('保存成功');
                            $(".s_carbtnbg").hide();
                        }
                    });



                },useCORS:true});
        });

    }


</script>
</html>

实现了web截图,效果不错!!!


本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/7201289.html,如需转载请自行联系原作者

相关文章
HTML+CSS 实现通用的企业官网页面(记得收藏)
HTML+CSS 实现通用的企业官网页面(记得收藏)
html页面点击按钮实现页面跳转功能
html页面点击按钮实现页面跳转
|
11天前
|
JavaScript 前端开发 Java
SpringBoot项目的html页面使用axios进行get post请求
SpringBoot项目的html页面使用axios进行get post请求
31 2
|
1月前
|
移动开发 前端开发 JavaScript
【HTML】HTML页面和常见标签
【HTML】HTML页面和常见标签
32 1
|
2月前
|
JavaScript 前端开发 Java
SpringBoot项目的html页面使用axios进行get post请求
SpringBoot项目的html页面使用axios进行get post请求
43 6
|
22天前
|
移动开发 HTML5
一个最简单的 HTML 页面结构如下:
HTML 是一种标记语言,用于描述网页结构。通过 `&lt;html&gt;`, `&lt;head&gt;`, `&lt;body&gt;` 等标签构建页面,支持文本、图像、链接、表格等多种元素。本文介绍了 HTML 基础,包括常用标签及创建简单网页的实例,帮助初学者快速入门。
55 0
|
1月前
|
XML Web App开发 数据格式
HTML 页面显示 XML 数据
10月更文挑战第2天
|
1月前
|
数据可视化 小程序 JavaScript
DIYGW可视化快速生成VUE3静态html页面
DIYGW可视化快速生成VUE3静态html页面
34 0
|
1月前
|
C#
C#实现的html内容截取.
C#实现的html内容截取.
13 0
|
3月前
|
缓存 Java 应用服务中间件
SpringMVC入门到实战------七、SpringMVC创建JSP页面的详细过程+配置模板+实现页面跳转+配置Tomcat。JSP和HTML配置模板的差异对比(二)
这篇文章详细介绍了在SpringMVC中创建JSP页面的全过程,包括项目的创建、配置、Tomcat的设置,以及如何实现页面跳转和配置模板解析器,最后还对比了JSP和HTML模板解析的差异。
SpringMVC入门到实战------七、SpringMVC创建JSP页面的详细过程+配置模板+实现页面跳转+配置Tomcat。JSP和HTML配置模板的差异对比(二)