1. 程式人生 > >QRCode.js 二維碼生成並能夠長按識別

QRCode.js 二維碼生成並能夠長按識別

今天天氣很好,窗外雲捲雲舒,溫度適宜,煦風。
泡一杯茶,坐下來,靜下心,思緒在我的程式碼王國裡翱翔,飛呀飛呀我的驕傲放縱。。。
。。飛累了,就停下來說說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; }