QRCode.js 二维码生成并能够长按识别
2017-05-12 11:24
459 查看
今天天气很好,窗外云卷云舒,温度适宜,煦风。
泡一杯茶,坐下来,静下心,思绪在我的代码王国里翱翔,飞呀飞呀我的骄傲放纵。。。
。。飞累了,就停下来说说QRCode.js生成二维码这头事吧!
QRCode.js 是一个用于生成二维码的 JavaScript 库。主要是通过获取 DOM 的标签,再通过 HTML5 Canvas 绘制而成,不依赖任何库。
首先引入QRCode.js文件,下载地址:http://davidshimjs.github.io/qrcodejs/
如果生成二维码的信息是固定不变的,那么当然不需要如此这般,网上有好多现成的二维码生成器,直接用就好。
可是,我的需求是这样的,二维码用于在微信或QQ中分享,根据不同的用户信息分别生成不同的二维码,这样就不能偷懒,就得用代码生成了,并且生成的二维码支持长按识别进入。
泡一杯茶,坐下来,静下心,思绪在我的代码王国里翱翔,飞呀飞呀我的骄傲放纵。。。
。。飞累了,就停下来说说QRCode.js生成二维码这头事吧!
QRCode.js 是一个用于生成二维码的 JavaScript 库。主要是通过获取 DOM 的标签,再通过 HTML5 Canvas 绘制而成,不依赖任何库。
首先引入QRCode.js文件,下载地址:http://davidshimjs.github.io/qrcodejs/
如果生成二维码的信息是固定不变的,那么当然不需要如此这般,网上有好多现成的二维码生成器,直接用就好。
可是,我的需求是这样的,二维码用于在微信或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; }
相关文章推荐
- 微信开发,解决jquery.qrcode.min.js生成二维码长按不识别问题
- QRCode.js二维码生成并能长按识别
- jquery.qrcode.js 插件生成二维码
- jQuery.qrcode.js客户端生成二维码,支持中文并且可以生成LOGO
- 二维码篇【一】【JS】使用jquery.qrcode生成二维码
- jquery.qrcode.js生成二维码插件&转成图片格式
- javaScript生成支持中文带logo的二维码(jquery.qrcode.js)
- 如何使用 jQuery.qrcode.js 生成二维码
- jQuery.qrcode.js客户端生成二维码,支持中文并且可以生成LOGO
- 使用jquery.qrcode.js生成二维码插件
- jquery.qrcode.min.js生成二维码插件
- (转)js jquery.qrcode生成二维码 带logo 支持中文
- 毛超帅 使用 jquery.qrcode.js 生成网站地址url二维码图片______软件开发-JAVA
- QRCode.js:使用 JavaScript 生成二维码
- 使用Jquery.QRCode.js在web客户端生成二维码包括中文
- jQuery.qrcode.js客户端生成二维码,支持中文并且可以生成LOGO
- Qrcode生成二维码(logo篇)之jquery.qrcode.min.js
- jquery.qrcode.min.js生成二维码 通过前端实现二维码生成
- 使用jquery.qrcode.js生成二维码插件
- QRCode.js 生成二维码