使用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 相关文章推荐
button在IE6/7下的黑边去除方案
Dec 24 HTML / CSS
CSS3制作ajax loader icon实现思路及代码
Aug 25 HTML / CSS
一款纯css3实现的圆形旋转分享按钮旋转角度可自己调整
Sep 02 HTML / CSS
详解css3 Transition属性(平滑过渡菜单栏案例)
Sep 05 HTML / CSS
canvas粒子动画背景的实现示例
Sep 03 HTML / CSS
HTML5制作酷炫音频播放器插件图文教程
Dec 30 HTML / CSS
用HTML5制作一个简单的桌球游戏的教程
May 12 HTML / CSS
html5 canvas移动浏览器上实现图片压缩上传
Mar 11 HTML / CSS
HTML5中原生的右键菜单创建方法
Jun 28 HTML / CSS
html5实现九宫格抽奖可固定抽中某项奖品
Jun 15 HTML / CSS
HTML5中在title标题标签里设置小图标的方法
Jun 23 HTML / CSS
canvas绘制图片drawImage使用方法
Sep 15 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
收音机另类DIY - 纸巾盒做外壳
2021/03/02 无线电
建立文件交换功能的脚本(一)
2006/10/09 PHP
第七节--类的静态成员
2006/11/16 PHP
php 将字符串按大写字母分隔成字符串数组
2010/04/30 PHP
smarty模板引擎中自定义函数的方法
2015/01/22 PHP
php实现SAE上使用storage上传与下载文件的方法
2015/06/29 PHP
JS TextArea字符串长度限制代码集合
2012/10/31 Javascript
jQuery ReferenceError: $ is not defined 错误的处理办法
2013/05/10 Javascript
JS实现5秒钟自动封锁div层的方法
2015/02/20 Javascript
JavaScript事件类型中UI事件详解
2016/01/14 Javascript
javascript每日必学之基础入门
2016/02/16 Javascript
基于JavaScript代码实现自动生成表格
2016/06/15 Javascript
AngularJS基础 ng-non-bindable 指令详细介绍
2016/08/02 Javascript
微信小程序 PHP后端form表单提交实例详解
2017/01/12 Javascript
ionic2 tabs 图标自定义实例
2017/03/08 Javascript
使用svg实现动态时钟效果
2018/07/17 Javascript
详解小程序输入框闪烁及重影BUG解决方案
2018/08/31 Javascript
解决vue 单文件组件中样式加载问题
2019/04/24 Javascript
Vue.js使用axios动态获取response里的data数据操作
2020/09/08 Javascript
Python中处理字符串之isalpha()方法的使用
2015/05/18 Python
在Python中操作列表之List.pop()方法的使用
2015/05/21 Python
Python建立Map写Excel表实例解析
2018/01/17 Python
python Pexpect 实现输密码 scp 拷贝的方法
2019/01/03 Python
对python3 Serial 串口助手的接收读取数据方法详解
2019/06/12 Python
对pyqt5之menu和action的使用详解
2019/06/20 Python
Pytorch中Tensor与各种图像格式的相互转化详解
2019/12/26 Python
django 解决自定义序列化返回处理数据为null的问题
2020/05/20 Python
如何快速理解python的垃圾回收机制
2020/09/01 Python
Python中猜拳游戏与猜筛子游戏的实现方法
2020/09/04 Python
python操作ini类型配置文件的实例教程
2020/10/30 Python
澳大利亚牛仔裤商店:Just Jeans
2016/10/13 全球购物
Monnier Frères美国官网:法国知名奢侈品网站
2016/11/22 全球购物
官方授权图形T恤和服装:Fifth Sun
2019/06/12 全球购物
如何保障Web服务器安全
2014/05/05 面试题
读《推着妈妈去旅行》有感1500字
2019/10/15 职场文书
python爬虫selenium模块详解
2021/03/30 Python