QRCode.js二维码生成并能长按识别
程序员文章站
2022-06-03 11:57:51
qrcode.js 是一个用于生成二维码的 javascript 库。主要是通过获取 dom 的标签,再通过 html5 canvas 绘制而成,不依赖任何库。
首先引入...
qrcode.js 是一个用于生成二维码的 javascript 库。主要是通过获取 dom 的标签,再通过 html5 canvas 绘制而成,不依赖任何库。
首先引入qrcode.js文件,
如果生成二维码的信息是固定不变的,那么当然不需要如此这般,网上有好多现成的二维码生成器,直接用就好。
可是,我的需求是这样的,二维码用于在微信或qq中分享,根据不同的用户信息分别生成不同的二维码,这样就不能偷懒,就得用代码生成了,并且生成的二维码支持长按识别进入。
话不多说,直接上干货:
html部分:
<div id="codebox"> <div id="qrdiv" style="display: none;"></div> <div id="qrcode"></div> </div>
js部分:实例化并进行参数设置:
var user_id="" //用户id user_id=getquerystring('user_id'); //获取user_id参数 var url= '' //请求url $(function(){ //生成二维码 var downurl=url+user_id; var qrcode = new qrcode("qrdiv", { text: utf16to8(url), render: "canvas", //渲染方式有table方式(ie兼容)和canvas方式 width: 128, height: 128, typenumber:-1,//计算模式 colordark : "#000000", //前景色 colorlight : "#ffffff", //背景色 correctlevel : qrcode.correctlevel.h //容错级别 }); var mycanvas1=document.getelementsbytagname('canvas')[0]; //将转换后的img标签插入到html中 var img=convertcanvastoimage(mycanvas1); $('#qrcode').append(img);//imagqrdiv表示你要插入的容器id }) //从 canvas 提取图片 image function convertcanvastoimage(canvas) { //新image对象,可以理解为dom var image = new image(); // canvas.todataurl 返回的是一串base64编码的url,当然,浏览器自己肯定支持 // 指定格式 png image.src = canvas.todataurl("image/png"); return image; } //获取请求参数值 function getquerystring(name) { var reg = new regexp('(^|&)' + name + '=([^&]*)(&|$)', 'i'); var r = window.location.search.substr(1).match(reg); if (r != null) { return unescape(r[2]); } return null; } //中文编码格式转换 function utf16to8(str) { var out, i, len, c; out = ""; len = str.length; for (i = 0; i < len; i++) { c = str.charcodeat(i); if ((c >= 0x0001) && (c <= 0x007f)) { out += str.charat(i); } else if (c > 0x07ff) { out += string.fromcharcode(0xe0 | ((c >> 12) & 0x0f)); out += string.fromcharcode(0x80 | ((c >> 6) & 0x3f)); out += string.fromcharcode(0x80 | ((c >> 0) & 0x3f)); } else { out += string.fromcharcode(0xc0 | ((c >> 6) & 0x1f)); out += string.fromcharcode(0x80 | ((c >> 0) & 0x3f)); } } return out; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: Vuex之理解Getters的用法实例
推荐阅读
-
QRCode.js二维码生成并能长按识别
-
PHP生成二维码与识别二维码的方法详解【附源码下载】
-
二维码图片生成器QRCode.js简单介绍
-
QRCode.js:使用 JavaScript 生成二维码
-
如何生成一个安卓和苹果手机都能识别的二维码
-
使用qrcode.js生成二维码
-
利用Zxing生成和识别二维码(java版本)
-
彩色二维码生成器,带logo文字和中心文字 彩色二维码生成器,带logo文字和中心文字 使用.net 4.0和zxing开发, 内容支持中文,使用UTF-8编码,一般扫描二维码软件可以识别。 最上方显示文字log,字数可以调节。 正中间的圆圈内显示中心文字。 微盘下载地址:彩色二维码生成器.net2.0win7可用byKimmKing.zip
-
彩色二维码生成器,带logo文字和中心文字 彩色二维码生成器,带logo文字和中心文字 使用.net 4.0和zxing开发, 内容支持中文,使用UTF-8编码,一般扫描二维码软件可以识别。 最上方显示文字log,字数可以调节。 正中间的圆圈内显示中心文字。 微盘下载地址:彩色二维码生成器.net2.0win7可用byKimmKing.zip
-
微信小程序里长按识别二维码的实现过程