使用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的支持状况
Oct 31 HTML / CSS
CSS3模块的目前的状况分析
Feb 24 HTML / CSS
纯CSS3打造属于自己的“小黄人”
Mar 14 HTML / CSS
涂鸦板简单实现 Html5编写属于自己的画画板
Jul 05 HTML / CSS
HTML5 实战PHP之Web页面表单设计
Oct 09 HTML / CSS
localstorage和sessionstorage使用记录(推荐)
May 23 HTML / CSS
从零实现一个自定义html5播放器的示例代码
Aug 01 HTML / CSS
HTML5实现移动端弹幕动画效果
Aug 01 HTML / CSS
HTML5自定义元素播放焦点图动画的实现
Sep 25 HTML / CSS
解决HTML5中的audio在手机端和微信端的不能自动播放问题
Nov 04 HTML / CSS
AmazeUI 手机版页面的顶部导航条Header与侧边导航栏offCanvas的示例代码
Aug 19 HTML / CSS
CSS浮动引起的高度塌陷问题
Aug 05 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
phpmyadmin 3.4 空密码登录的实现方法
2010/05/29 PHP
PDO防注入原理分析以及使用PDO的注意事项总结
2014/10/23 PHP
PHP使用http_build_query()构造URL字符串的方法
2016/04/02 PHP
PHP实现对数组分页处理实例详解
2017/02/07 PHP
PHP 中 var_export、print_r、var_dump 调试中的区别
2018/06/19 PHP
php JWT在web端中的使用方法教程
2018/09/06 PHP
jQuery中RadioButtonList的功能及用法实例介绍
2013/08/23 Javascript
javascript图片相似度算法实现 js实现直方图和向量算法
2014/01/14 Javascript
Javascript中引用示例介绍
2014/02/21 Javascript
jquery淡化版banner异步图片文字效果切换图片特效
2014/04/08 Javascript
jquery动态调整div大小使其宽度始终为浏览器宽度
2014/06/06 Javascript
JQuery 在线引用及测试引用是否成功
2014/06/24 Javascript
修改或扩展jQuery原生方法的代码实例
2015/01/13 Javascript
js窗口关闭提示信息(兼容IE和firefox)
2015/10/23 Javascript
基于Echarts 3.19 制作常用的图形(非静态)
2016/05/19 Javascript
JavaScript获取tr td 的三种方式全面总结(推荐)
2017/08/15 Javascript
JS实现在文本指定位置插入内容的简单示例
2017/12/22 Javascript
解决Layui 表单提交数据为空的问题
2018/08/15 Javascript
微信小程序模板消息推送的两种实现方式
2019/08/27 Javascript
Vue实现简单的拖拽效果
2020/08/25 Javascript
Python标准库之随机数 (math包、random包)介绍
2014/11/25 Python
理解Python中函数的参数
2015/04/27 Python
python 从文件夹抽取图片另存的方法
2018/12/04 Python
Python使用folium excel绘制point
2019/01/03 Python
selenium跳过webdriver检测并模拟登录淘宝
2019/06/12 Python
python爬虫开发之Beautiful Soup模块从安装到详细使用方法与实例
2020/03/09 Python
数控技术专业推荐信
2013/11/01 职场文书
优秀辅导员事迹材料
2014/02/16 职场文书
幼儿园小班评语
2014/04/18 职场文书
2015年社区科普工作总结
2015/05/13 职场文书
小学数学教师研修日志
2015/11/13 职场文书
表扬信范文
2019/04/22 职场文书
Golang 使用Map实现去重与set的功能操作
2021/04/29 Golang
Python开发工具Pycharm的安装以及使用步骤总结
2021/06/24 Python
JavaScript实现优先级队列
2021/12/06 Javascript
Golang 链表的学习和使用
2022/04/19 Golang