QRCode.js二維碼生成并能長按識別
QRCode.js 是一個用于生成二維碼的 JavaScript 庫。主要是通過獲取 DOM 的標(biāo)簽,再通過 HTML5 Canvas 繪制而成,不依賴任何庫。
首先引入QRCode.js文件,下載地址
如果生成二維碼的信息是固定不變的,那么當(dāng)然不需要如此這般,網(wǎng)上有好多現(xiàn)成的二維碼生成器,直接用就好。
可是,我的需求是這樣的,二維碼用于在微信或QQ中分享,根據(jù)不同的用戶信息分別生成不同的二維碼,這樣就不能偷懶,就得用代碼生成了,并且生成的二維碼支持長按識別進(jìn)入。
話不多說,直接上干貨:
html部分:
<div id="codeBox"> <div id="qrDiv" style="display: none;"></div> <div id="qrcode"></div> </div>
js部分:實例化并進(jìn)行參數(shù)設(shè)置:
var user_id="" //用戶ID user_id=getQueryString('user_id'); //獲取user_id參數(shù) 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]; //將轉(zhuǎn)換后的img標(biāo)簽插入到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,當(dāng)然,瀏覽器自己肯定支持 // 指定格式 PNG image.src = canvas.toDataURL("image/png"); return image; } //獲取請求參數(shù)值 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; } //中文編碼格式轉(zhuǎn)換 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; }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript sudoku 數(shù)獨智力游戲生成代碼
javascript sudoku 數(shù)獨智力游戲生成代碼,喜歡的朋友可以參考下。2010-03-03js在指定位置增加節(jié)點函數(shù)insertBefore()用法實例
這篇文章主要介紹了js在指定位置增加節(jié)點函數(shù)insertBefore()用法,實例分析了insertBefore()函數(shù)追加結(jié)點的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-01-01動態(tài)規(guī)劃之使用備忘錄來改進(jìn)Javascript函數(shù)
這篇文章主要介紹了動態(tài)規(guī)劃之使用備忘錄來改進(jìn)Javascript函數(shù),動態(tài)規(guī)劃它既是一種數(shù)學(xué)優(yōu)化方法,也是一種計算機(jī)編程方法,下文相關(guān)資料介紹需要的小伙伴可以參考一下2022-04-04Spring Boot+AngularJS+BootStrap實現(xiàn)進(jìn)度條示例代碼
一般上傳文件時都需要進(jìn)度條,本篇文章主要介紹了Spring Boot+AngularJS+BootStrap實現(xiàn)進(jìn)度條示例代碼,有興趣的可以了解一下。2017-03-03Express與NodeJs創(chuàng)建服務(wù)器的兩種方法
本文主要介紹了NodeJs創(chuàng)建Web服務(wù)器;Express創(chuàng)建Web服務(wù)器的兩種方法,具有一定的參考價值,下面跟著小編一起來看下吧2017-02-02