功能需求:html
总体实现流程:前端
使用的第三方库:canvas
下面是具体实现步骤:bash
1、设计html元素布局微信
template部分dom
<template>
<!-- 海报html元素 -->
<div id="posterHtml" :style="{backgroundImage: 'url('+posterHtmlBg+')'}" v-show="false">
<div>{{posterContent}}</div>
<!-- 二维码 -->
<div class="qrcode"><div id="qrcodeImg"></div></div>
</div>
</template>复制代码
script部分:布局
<script>
import QRCode from 'qrcodejs2'
import html2canvas from 'html2canvas'
export default {
data() {
return {
posterContent: '', // 文案内容
posterHtmlBg: require('../../assets/images/poster/invite_poster_bg.jpg'), // 背景图
posterImg: '', // 最终生成的海报图片
}
},
}
</script>
复制代码
2、合成二维码图片post
methods: {
createQrcode(text) {
// 生成二维码
const qrcodeImgEl = document.getElementById('qrcodeImg')
qrcodeImgEl.innerHTML = ''
let qrcode = new QRCode(qrcodeImgEl, {
width: 256,
height: 256,
colorDark: '#000000',
colorLight: '#ffffff',
correctLevel: QRCode.CorrectLevel.H
})
qrcode.makeCode(text)
},
}
复制代码
3、将html元素转换成海报图片网站
methods: {
createPoster() {
// 生成海报
const vm = this
const domObj = document.getElementById('posterHtml')
html2canvas(domObj, {
useCORS: true,
allowTaint: false,
logging: false,
letterRendering: true,
onclone(doc) {
let e = doc.querySelector('#posterHtml')
e.style.display = 'block'
}
}).then(function(canvas) {
// 在微信里,可长按保存或转发
vm.posterImg = canvas.toDataURL('image/png')
})
},
}
复制代码
注意: 添加html2canvas对象的onclone方法是为了 生成一个复制的虚拟组件,设置为显示,便可获取进行绘制,且虚拟组件不会显示在页面上.ui
福利: 本文已同步到个人我的技术网站 IT干货-sufaith 该网站包括Python, Linux, Nodejs, 前端开发等模块, 专一于程序开发中的技术、经验总结与分享, 欢迎访问.