首页前端开发HTML使用html2canvas实现将html内容写入到canvas中生成图片

使用html2canvas实现将html内容写入到canvas中生成图片

时间2024-01-25 02:03:25发布访客分类HTML浏览125
导读:收集整理的这篇文章主要介绍了使用html2canvas实现将html内容写入到canvas中生成图片,觉得挺不错的,现在分享给大家,也给大家做个参考。 之前我们简单的了解了canvas的基本用法,这里我们来了解下如何将htML内容...
收集整理的这篇文章主要介绍了使用html2canvas实现将html内容写入到canvas中生成图片,觉得挺不错的,现在分享给大家,也给大家做个参考。

之前我们简单的了解了canvas的基本用法,这里我们来了解下如何将htML内容写入到canvas中生成图片,这里我使用到了html2canvas插件,这个插件是基于canvas实现的

html2canvas官网: http://html2canvas.hertzen.com/

一:下载html2canvas插件

1:直接下载html2canvas插件

直接点击html2canvas.min.js,然后直接ctrl+s进行保存即可

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 @R_777_2150@ '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内容传到服务端,服务端可以将图片进行保存起来

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

html

若转载请注明出处: 使用html2canvas实现将html内容写入到canvas中生成图片
本文地址: https://pptw.com/jishu/586014.html
使用canvas实现黑客帝国数字雨效果 HTML5去掉输入框type为number时的上下箭头的实现方法

游客 回复需填写必要信息