使用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的@media来编写响应式的页面
Nov 01 HTML / CSS
详解HTML5中的标签
Jun 19 HTML / CSS
用HTML5实现手机摇一摇的功能的教程
Oct 30 HTML / CSS
html5指南-4.使用Geolocation实现定位功能
Jan 07 HTML / CSS
html5教程制作简单画板代码分享
Dec 04 HTML / CSS
html5组织内容_动力节点Java学院整理
Jul 10 HTML / CSS
HTML5页面中尝试调起APP功能
Sep 12 HTML / CSS
web字体加载方案优化小结
Nov 29 HTML / CSS
AmazeUI 按钮交互的实现示例
Aug 24 HTML / CSS
Canvas在超级玛丽游戏中的应用详解
Feb 06 HTML / CSS
html5实现点击弹出图片功能
Jul 16 HTML / CSS
CSS list-style-type属性使用方法
May 21 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
php中随机函数mt_rand()与rand()性能对比分析
2014/12/01 PHP
PHP 二维数组和三维数组的过滤
2016/03/16 PHP
浅谈PHP Cookie处理函数
2016/06/10 PHP
PHP实现模拟http请求的方法分析
2017/12/20 PHP
php 字符串中是否包含指定字符串的多种方法
2018/04/12 PHP
在Laravel中使用DataTables插件的方法
2018/05/29 PHP
PHP实现Snowflake生成分布式唯一ID的方法示例
2020/08/30 PHP
用js通过url传参把数据从一个页面传到另一个页面
2014/09/01 Javascript
jQuery实现伪分页的方法分享
2016/02/17 Javascript
基于Bootstrap实现Material Design风格表单插件 附源码下载
2016/04/18 Javascript
使用Angular缓存父页面数据的方法
2017/01/03 Javascript
js获取json中key所对应的value值的简单方法
2020/06/17 Javascript
以BootStrap Tab为例写一个前端组件
2017/07/25 Javascript
详解Js里的for…in和for…of的用法
2019/03/28 Javascript
CKEditor 4.4.1 添加代码高亮显示插件功能教程【使用官方推荐Code Snippet插件】
2019/06/14 Javascript
JavaScript实现刮刮乐效果
2020/11/01 Javascript
Python工程师面试必备25条知识点
2018/01/17 Python
tensorflow实现简单的卷积神经网络
2018/05/24 Python
python机器学习之KNN分类算法
2018/08/29 Python
TensorFlow实现Logistic回归
2018/09/07 Python
python中退出多层循环的方法
2018/11/27 Python
Python函数式编程指南:对生成器全面讲解
2019/11/19 Python
Python如何基于selenium实现自动登录博客园
2019/12/16 Python
TensorFlow tf.nn.conv2d实现卷积的方式
2020/01/03 Python
解决windows上安装tensorflow时报错,“DLL load failed: 找不到指定的模块”的问题
2020/05/20 Python
Python参数传递机制传值和传引用原理详解
2020/05/22 Python
Python如何给函数库增加日志功能
2020/08/04 Python
python如何获得list或numpy数组中最大元素对应的索引
2020/11/16 Python
python+selenium+chrome实现淘宝购物车秒杀自动结算
2021/01/07 Python
python 统计list中各个元素出现的次数的几种方法
2021/02/20 Python
知识竞赛拉拉队口号
2014/06/16 职场文书
大学生求职信
2014/06/17 职场文书
应届生求职自荐信
2014/07/04 职场文书
2014党员干部四风问题对照检查材料思想汇报
2014/09/24 职场文书
2015年试用期工作总结范文
2015/05/28 职场文书
纯CSS3实现div按照顺序出入效果
2021/07/15 HTML / CSS