时间:2021-05-08
之前我们简单的了解了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 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内容传到服务端,服务端可以将图片进行保存起来
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
第一步,把网页保存为Canvas画布,借助于html2canvas库,http://html2canvas.hertzen.com/html2canvas(do
使用html2canvas实现浏览器截图,必须在服务器环境下才能实现。作用html2canvas可以通过纯JS对浏览器端经行截屏,但截图的精确度还有待提高,部分
html2canvas是一个将html元素生成canvas的库,绘制的canvas大部分样式和CSS一致。比如截止1.0.0-alpha.12,虚线边框依然绘制
最近项目一个功能需求,需实现将两张图片合成后下载的一个功能。分析完功能需求后,决定直接使用前端技术来实现。为提高效率,使用插件(html2canvas)配合编写
最近工作需求需要生成分享图片,最初用js的html2canvas截图插件各种问题,后来干脆PHP的PG库在后台生成图片,很愉快的解决了各种问题,我们要实现的效果