如何基于原生javaScript生成带图片的二维码
这篇文章主要介绍了如何基于原生javaScript生成带图片的二维码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
使用链接生成二维码主要是使用qr.js或者其他,把链接转化为二维码的形式,在使用canvas时需要设置画布的尺寸,生成的颜色。
js functioncreateQr(){//生成带图片二维码 constqrcode=qr('http://baidu.com')//转化链接 constcanvas=this.$refs.canvas constctx=canvas.getContext('2d') constsize=128/qrcode.moduleCount//128设置的二维码尺寸 constscale=window.devicePixelRatio/getPixelRatio(ctx) canvas.height=canvas.width=128e*scale ctx.scale(scale,scale) qrcode.modules.forEach((row,rdx)=>{ row.forEach((cell,cdx)=>{ ctx.fillStyle=cell?'#000':'#fff'//设置二维码颜色和背景颜色 varw=(Math.ceil((cdx+1)*size)-Math.floor(cdx*size)) ctx.fillRect(Math.round(cdx*size),Math.round(rdx*size),w,w) }) }) varimage=document.createElement('img') varimgcode=document.getElementById('imgcode') image.src='http://baidu/logo.png'//二维码中间图标 image.onload=()=>{ vardwidth=128*0.2//设置图片大小 vardx=(128-dwidth)/2 vardheight=image.height/image.width*dwidth vardy=(this.size-dheight)/2 image.width=dwidth image.height=dheight ctx.drawImage(image,dx,dy,dwidth,dheight) imgcode.src=canvas.toDataURL() } }, getPixelRatio(ctx){ returnctx.webkitBackingStorePixelRatio||ctx.backingStorePixelRatio||1 }以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。