使用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实现文字向右循环闪过效果实例(可用于移动端)
Jun 15 HTML / CSS
简单介绍CSS3中Media Query的使用
Jul 07 HTML / CSS
利用CSS3的线性渐变linear-gradient制作边框的示例
Jun 02 HTML / CSS
谈谈对css属性box-sizing的了解
Jan 04 HTML / CSS
CSS3实现线性渐变用法示例代码详解
Aug 07 HTML / CSS
html5 web本地存储将取代我们的cookie
Dec 26 HTML / CSS
HTML5 Canvas中绘制椭圆的4种方法
Apr 24 HTML / CSS
HTML5 history新特性pushState、replaceState及两者的区别
Dec 26 HTML / CSS
HTML5和CSS3实例教程总结(推荐)
Jul 18 HTML / CSS
h5网页水印SDK的实现代码示例
Feb 19 HTML / CSS
AmazeUI图片轮播效果的示例代码
Aug 20 HTML / CSS
css中:last-child不生效的解决方法
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
PHP分页类集锦
2014/11/18 PHP
php程序总是提示验证码输入有误解决方案
2015/01/07 PHP
让Laravel API永远返回JSON格式响应的方法示例
2018/09/05 PHP
jQuery 遍历json数组的实现代码
2020/09/22 Javascript
jQuery温习篇 强大的JQuery选择器
2010/04/24 Javascript
onclick与listeners的执行先后问题详细解剖
2013/01/07 Javascript
自定义jQuery选项卡插件实例
2013/03/27 Javascript
多个jQuery版本共存的处理方案
2015/03/17 Javascript
IE7浏览器窗口大小改变事件执行多次bug及IE6/IE7/IE8下resize问题
2015/08/21 Javascript
jquery UI Datepicker时间控件的使用方法(基础版)
2015/11/07 Javascript
第三章之Bootstrap 表格与按钮功能
2016/04/25 Javascript
AngularJS 模块详解及简单实例
2016/07/28 Javascript
ajax 提交数据到后台jsp页面及页面跳转问题
2017/01/19 Javascript
node.js中express中间件body-parser的介绍与用法详解
2017/05/23 Javascript
微信小程序template模板实例详解
2017/10/27 Javascript
详解vue2.0监听属性的使用心得及搭配计算属性的使用
2018/07/18 Javascript
JS实现二维数组元素的排列组合运算简单示例
2019/01/28 Javascript
JavaScript前端页面搜索功能案例【基于jQuery】
2019/07/10 jQuery
原生js实现无缝轮播图
2020/01/11 Javascript
Vue 禁用浏览器的前进后退操作
2020/09/04 Javascript
谈谈JavaScript中的函数
2020/09/08 Javascript
ant-design-vue 时间选择器赋值默认时间的操作
2020/10/27 Javascript
python双向链表实现实例代码
2013/11/21 Python
Python之csv文件从MySQL数据库导入导出的方法
2018/06/21 Python
python中plot实现即时数据动态显示方法
2018/06/22 Python
Python实现FTP文件传输的实例
2019/07/07 Python
Python列表(list)所有元素的同一操作解析
2019/08/01 Python
Python tempfile模块生成临时文件和临时目录
2020/09/30 Python
Python3中FuzzyWuzzy库实例用法
2020/11/18 Python
世界顶级户外运动品牌折扣网站:LeftLane Sports
2019/06/12 全球购物
《大海那边》教学反思
2014/04/09 职场文书
股东出资证明书(正规版)
2014/09/24 职场文书
2014年销售经理工作总结
2014/12/01 职场文书
2015年度合同管理工作总结
2015/05/22 职场文书
担保书怎么写 ?
2019/04/22 职场文书
Java基础之线程锁相关知识总结
2021/06/30 Java/Android