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

2020-04-25 07:30:44易采站长站整理

之前我们简单的了解了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',//画布的背景色,默认为透明