使用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 和 HTML5 兼容速查表 图文
Apr 01 HTML / CSS
纯css3显示隐藏一个div特效的具体实现
Feb 10 HTML / CSS
CSS3颜色值RGBA与渐变色使用介绍
Mar 06 HTML / CSS
css3实现平移效果(transfrom:translate)的示例
Nov 13 HTML / CSS
Canvas 文本转粒子效果的实现代码
Feb 14 HTML / CSS
html5定位并在百度地图上显示的示例
Apr 27 HTML / CSS
实例讲解HTML5的meta标签的一些应用
Dec 08 HTML / CSS
基于HTML5新特性Mutation Observer实现编辑器的撤销和回退操作
Jan 11 HTML / CSS
HTML5 表单验证失败的提示语问题
Jul 13 HTML / CSS
通过canvas转换颜色为RGBA格式及性能问题的解决
Nov 22 HTML / CSS
HTML5实现直播间评论滚动效果的代码
May 27 HTML / CSS
amazeui页面分析之登录页面的示例代码
Aug 25 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
Yii实现单用户博客系统文章详情页插入评论表单的方法
2015/12/28 PHP
php实现文件管理与基础功能操作
2017/03/21 PHP
PHP FileSystem 文件系统常用api整理总结
2019/07/12 PHP
优秀js开源框架-jQuery使用手册(1)
2007/03/10 Javascript
JS获得URL超链接的参数值实例代码
2013/06/21 Javascript
Jquery easyui 下loaing效果示例代码
2013/08/12 Javascript
jQuery避免$符和其他JS库冲突的方法对比
2014/02/20 Javascript
Node.js模块加载详解
2014/08/16 Javascript
关于JavaScript和jQuery的类型判断详解
2016/10/08 Javascript
etmvc+jQuery EasyUI+combobox多值操作实现角色授权实例
2016/11/09 Javascript
使用Xcache缓存器加速PHP网站的配置方法
2017/04/22 Javascript
详解JS数值Number类型
2018/02/07 Javascript
Vue使用mixin分发组件的可复用功能
2019/09/01 Javascript
vue+vant-UI框架实现购物车的复选框全选和反选功能
2019/11/05 Javascript
vue-video-player视频播放器使用配置详解
2020/10/23 Javascript
[03:09]2014DOTA2国际邀请赛 Mushi前队友送上祝福
2014/07/12 DOTA
[06:14]《辉夜杯》外卡赛附加赛 4支战队巡礼
2015/10/23 DOTA
[01:32]2016国际邀请赛中国区预选赛IG战队首日赛后采访
2016/06/27 DOTA
Python实现二叉堆
2016/02/03 Python
Python实现简单网页图片抓取完整代码实例
2017/12/15 Python
python 实现提取某个索引中某个时间段的数据方法
2019/02/01 Python
python Event事件、进程池与线程池、协程解析
2019/10/25 Python
使用TensorFlow-Slim进行图像分类的实现
2019/12/31 Python
Python3使用xlrd、xlwt处理Excel方法数据
2020/02/28 Python
Python使用Pygame绘制时钟
2020/11/29 Python
纯CSS3实现的井字棋游戏
2020/11/25 HTML / CSS
巴西一家专门从事家居和装饰的连锁店:Camicado
2019/08/14 全球购物
法国购买隐形眼镜和眼镜网站:Optical Center
2019/10/08 全球购物
Dr. Martens马汀博士德国官网:马丁靴鼻祖
2019/12/26 全球购物
几个Linux面试题笔试题
2012/12/01 面试题
电子商务专业毕业生工作推荐信
2013/11/17 职场文书
开朗女孩的自我评价
2014/02/10 职场文书
降消项目实施方案
2014/03/30 职场文书
消防安全宣传口号
2014/06/10 职场文书
2015年国庆节活动总结
2015/03/23 职场文书
CSS3 制作的书本翻页特效
2021/04/13 HTML / CSS