使用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悬停效果案例应用
Nov 21 HTML / CSS
纯CSS3实现扇形动画菜单(简化版)实例源码
Jan 17 HTML / CSS
CSS3实现伪类hover离开时平滑过渡效果示例
Aug 10 HTML / CSS
详解css3中的伪类before和after常见用法
Nov 17 HTML / CSS
css3实现书本翻页效果的示例代码
Mar 08 HTML / CSS
html5 canvas实现跟随鼠标旋转的箭头
Mar 11 HTML / CSS
HTML5边玩边学(1)画布实现方法
Sep 21 HTML / CSS
用HTML5实现网站在windows8中贴靠的方法
Apr 21 HTML / CSS
利用HTML5的新特点实现图片文件异步上传
May 29 HTML / CSS
HTML5进度条特效
Dec 18 HTML / CSS
深入理解HTML5定时器requestAnimationFrame的使用
Dec 12 HTML / CSS
iPhoneX安全区域(Safe Area)底部小黑条在微信小程序和H5的屏幕适配
Apr 08 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
Ping服务的php实现方法,让网站快速被收录
2012/02/04 PHP
浅析php插件 Simple HTML DOM 用DOM方式处理HTML
2013/07/01 PHP
PHP中nowdoc和heredoc使用需要注意的一点
2014/03/21 PHP
laravel入门知识点整理
2020/09/15 PHP
javascript一些不错的函数脚本代码
2008/09/10 Javascript
ajax 同步请求和异步请求的差异分析
2011/07/04 Javascript
jQuery Ajax使用实例
2015/04/16 Javascript
JavaScript实现时间倒计时跳转(推荐)
2016/06/28 Javascript
Bootstrap表单布局样式源代码
2016/07/04 Javascript
jquery判断对象是否为空并遍历对象的简单实例
2016/07/26 Javascript
VUE JS 使用组件实现双向绑定的示例代码
2017/01/10 Javascript
jQuery插件zTree实现删除树子节点的方法示例
2017/03/08 Javascript
Bootstrap Table使用整理(二)
2017/06/09 Javascript
搭建element-ui的Vue前端工程操作实例
2018/02/23 Javascript
详解vue 单页应用(spa)前端路由实现原理
2018/04/04 Javascript
Vue2.0生命周期的理解
2018/08/20 Javascript
Node.js Event Loop各阶段讲解
2019/03/08 Javascript
Vue父子传递实例讲解
2020/02/14 Javascript
[02:45]DOTA2英雄敌法师基础教程
2013/11/25 DOTA
Python通过select实现异步IO的方法
2015/06/04 Python
理解Python中的绝对路径和相对路径
2017/08/30 Python
python利用urllib和urllib2访问http的GET/POST详解
2017/09/27 Python
基于Python os模块常用命令介绍
2017/11/03 Python
python网络编程socket实现服务端、客户端操作详解
2020/03/24 Python
python使用bs4爬取boss直聘静态页面
2020/10/10 Python
python3爬虫GIL修改多线程实例讲解
2020/11/24 Python
2019年Java面试必问之经典试题
2012/09/12 面试题
.NET初级开发工程师面试题
2014/04/18 面试题
口腔工艺技术专业毕业生自荐信
2013/09/27 职场文书
致400米运动员广播稿
2014/02/07 职场文书
老干部工作汇报材料
2014/10/28 职场文书
2014年教研员工作总结
2014/12/23 职场文书
授权委托书
2015/01/28 职场文书
奥巴马开学演讲观后感
2015/06/12 职场文书
总经理致辞
2015/07/29 职场文书
导游词之白茶谷九龙峡
2019/10/23 职场文书