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


Posted in HTML / CSS onJanuary 03, 2020

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

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

一:下载html2canvas插件

1:直接下载html2canvas插件

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

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

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内容传到服务端,服务端可以将图片进行保存起来

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

HTML / CSS 相关文章推荐
CSS3 三维变形实现立体方块特效源码
Dec 15 HTML / CSS
CSS3中Transform动画属性用法详解
Jul 04 HTML / CSS
使用CSS3编写灰阶滤镜来制作黑白照片效果的方法
May 09 HTML / CSS
使用CSS3的box-sizing属性解决div宽高被内边距撑开的问题
Jun 28 HTML / CSS
CSS3动画:5种预载动画效果实例
Apr 05 HTML / CSS
html5使用html2canvas实现浏览器截图的示例
Aug 31 HTML / CSS
html5 viewport使用方法示例详解
Dec 02 HTML / CSS
用HTML5 实现橡皮擦的涂抹效果的教程
May 11 HTML / CSS
详解HTML5中ol标签的用法
Sep 08 HTML / CSS
HTML5 移动页面自适应手机屏幕四类方法总结
Aug 17 HTML / CSS
Html5 滚动穿透的方法
May 13 HTML / CSS
CSS font-variation 可变字体的魅力(实例详解)
Mar 03 HTML / CSS
HTML5去掉输入框type为number时的上下箭头的实现方法
Jan 03 #HTML / CSS
使用canvas实现黑客帝国数字雨效果
Jan 02 #HTML / CSS
HTML5中外部浏览器唤起微信分享
Jan 02 #HTML / CSS
Html5获取高德地图定位天气的方法
Dec 26 #HTML / CSS
鼠标滚轮事件和Mac触控板双指事件
Dec 23 #HTML / CSS
HTML5 Canvas 实现K线图的示例代码
Dec 23 #HTML / CSS
html5利用canvas实现颜色容差抠图功能
Dec 23 #HTML / CSS
You might like
sphinx增量索引的一个问题
2011/06/14 PHP
PHP生成迅雷、快车、旋风等软件的下载链接代码实例
2014/05/12 PHP
PHP中实现crontab代码分享
2015/03/26 PHP
搭建自己的PHP MVC框架详解
2017/08/16 PHP
从sohu弄下来的flash中展示图片的代码
2007/04/27 Javascript
JavaScript DOM 学习第二章 编辑文本
2010/02/19 Javascript
javascript代码编写需要注意的7个小细节小结
2011/09/21 Javascript
js控制不同的时间段显示不同的css样式的实例代码
2013/11/04 Javascript
得到form下的所有的input的js代码
2013/11/07 Javascript
node.js中的fs.readFile方法使用说明
2014/12/15 Javascript
jquery调取json数据实现省市级联的方法
2015/01/29 Javascript
jQuery扩展实现text提示还能输入多少字节的方法
2016/11/28 Javascript
jQuery实现单击按钮遮罩弹出对话框效果(2)
2017/02/20 Javascript
BootStrap Table 后台数据绑定、特殊列处理、排序功能
2017/05/27 Javascript
ReactJs设置css样式的方法
2017/06/08 Javascript
使用vue-router完成简单导航功能【推荐】
2018/06/28 Javascript
js实现延迟加载的几种方法详解
2019/01/19 Javascript
[51:34]Ti4主赛事胜者组 DK vs EG 2
2014/07/19 DOTA
[08:54]DOTA2-DPC中国联赛 正赛 Aster vs LBZS 选手采访
2021/03/11 DOTA
回调函数的意义以及python实现实例
2017/06/20 Python
20个常用Python运维库和模块
2018/02/12 Python
Python实现对文件进行单词划分并去重排序操作示例
2018/07/10 Python
解决Pycharm界面的子窗口不见了的问题
2019/01/17 Python
PyTorch 导数应用的使用教程
2020/08/31 Python
python 合并多个excel中同名的sheet
2021/01/22 Python
Jeep牧马人、切诺基和自由人零配件:4 Wheel Drive Hardware
2017/07/02 全球购物
城市轨道专业个人求职信范文
2013/09/23 职场文书
专科毕业生自我鉴定
2013/12/01 职场文书
前台文员岗位职责
2013/12/28 职场文书
办公室岗位职责
2014/02/12 职场文书
计算机专业毕业生自荐信范文
2014/03/06 职场文书
物业工程部主管岗位职责
2015/04/16 职场文书
加班费申请报告
2015/05/15 职场文书
护士医德医风心得体会
2016/01/25 职场文书
Pytorch 如何加速Dataloader提升数据读取速度
2021/05/28 Python
Vue如何清空对象
2022/03/03 Vue.js