• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    使用html2canvas实现将html内容写入到canvas中生成图片

    之前我们简单的了解了canvas的基本用法,这里我们来了解下如何将html内容写入到canvas中生成图片,这里我使用到了html2canvas插件,这个插件是基于canvas实现的

    html2canvas官网: http://html2canvas.hertzen.com/

    一:下载html2canvas插件

    1:直接下载html2canvas插件

    直接点击html2canvas.min.js,然后直接ctrl+s进行保存即可

    2:使用npm进行下载

    npm install html2canvas

    二:html2canvas使用介绍

    在html2canvas中主要使用两种方法

    1:将html内容写入到canvas中

    html2canvas(element,options).then((canvas) =>{})

    参数说明:

    element:需要将html内容写入canvas的jQuery对象

    options:配置信息

    常用的配置基本信息:

    scale:缩放比例,默认为1

    allowTaint:是否允许跨域图像污染画布,默认为false

    useCORS:是否尝试使用CORS从服务器加载图像,默认为false

    width:canvas画布的宽度,默认为jQuery对象的宽度

    height:canvas画布的高度,默认为jQuery对象的高度

    backgroundColor:/画布的背景色,默认为透明(#fff),参数可以为#表示的颜色,也可以使用rgba

    2:将canvas画布信息转化为base64格式图片

    canvas.toDataURL("image/png")

    如果你的html内容中有指定的内容不写入到canvas中的话,你可以给标签添加如下属性

    data-html2canvas-ignore="true"

    三:简单实例

    1:引入html2canvas

    <script src="js/html2canvas.min.js"></script>

    或者使用import引入html2canvas

    import html2canvas from 'html2canvas';

    2:需要转化的的html内容

    <div class="capture">
        <img src="./wj.jpg" alt="">
        <div>
            <span style="color: #f00;letter-spacing: 20px">这是文字文字</span>
            <span data-html2canvas-ignore="true">不写入canvas</span>
        </div>
    </div>

    3:将html内容写入canvas并转化为base64图片

    html2canvas(document.getElementsByClassName("capture")[0], {
            scale: 2,//缩放比例,默认为1
            allowTaint: false,//是否允许跨域图像污染画布
            useCORS: true,//是否尝试使用CORS从服务器加载图像
            width: '500',//画布的宽度
            height: '500',//画布的高度
            backgroundColor: '#000000',//画布的背景色,默认为透明
        }).then((canvas) => {
            //将canvas转为base64格式
            var imgUri = canvas.toDataURL("image/png");
        });
    这里注意jQuery对象是do

    这里注意jQuery对象是document.getElementsByClassName("capture")[0]而不是document.getElementsByClassName("capture"),document.getElementsByClassName("capture")是DOM原生对象而不是jQuery对象

    根据如上就可以实现将html内容写入canvas并转化为base64图片,这时候我们就可以将base64内容传到服务端,服务端可以将图片进行保存起来

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

    上一篇:HTML5去掉输入框type为number时的上下箭头的实现方法
    下一篇:HTML5自定义视频播放器源码
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    使用html2canvas实现将html内容写入到canvas中生成图片 使用,html2canvas,实,现将,