今天天气很好,窗外云卷云舒,温度适宜,煦风。
泡一杯茶,坐下来,静下心,思绪在我的代码王国里翱翔,飞呀飞呀我的骄傲放纵。。。
。。飞累了,就停下来说说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=""
user_id=getQueryString('user_id');
var url= ''
$(function(){
var downUrl=url+user_id;
var qrcode = new QRCode("qrDiv", {
text: utf16to8(Url),
render: "canvas",
width: 128,
height: 128,
typeNumber:-1,
colorDark : "#000000",
colorLight : "#ffffff",
correctLevel : QRCode.CorrectLevel.H
var mycanvas1=document.getElementsByTagName('canvas')[0];
var img=convertCanvasToImage(mycanvas1);
$('#qrcode').append(img);
function convertCanvasToImage(canvas) {
var image = new Image();
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;
QRCode.js 是一个用于生成二维码的 JavaScript 库。主要是通过获取 DOM 的标签,再通过 HTML5 Canvas 绘制而成,不依赖任何库。
首先引入QRCode.js文件,下载地址
如果生成二维码的信息是固定不变的,那么当然不需要如此这般,网上有好多现成的二维码生成器,直接用就好。
可是,我的需求是这样的,二维码用于在微信或QQ中分享,根据不同的用户信息分别生成不同的二维码,这样就不能偷懒,就得用代码生成了,并且生成的二维码支持长按识别进入。
话不多说,直接上干货:
html部分:
<div id=codeBox>
<div id=qrDiv style=d
"jquery-1.8.3.js" type="text/javascript" charset="utf-8">
"jquery.qrcode.min.js" type="text/javascript" charset="utf-8">
2.在页面
浏览器打开