国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-19 12:41:37
字體:
供稿:網(wǎng)友

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部分:實(shí)例化并進(jìn)行參數(shù)設(shè)置:

var user_id="" //用戶IDuser_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,//計(jì)算模式    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í)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 鄂温| 平泉县| 龙南县| 班玛县| 岳阳市| 炎陵县| 英山县| 梓潼县| 德江县| 昔阳县| 滨州市| 天全县| 九江县| 大渡口区| 泗洪县| 冕宁县| 玛纳斯县| 搜索| 中江县| 巴彦淖尔市| 丰顺县| 双鸭山市| 宜兴市| 山西省| 青海省| 东山县| 朝阳县| 三门县| 渭源县| 永安市| 衡阳县| 荣成市| 上思县| 通海县| 枞阳县| 沧源| 阳谷县| 永平县| 新巴尔虎右旗| 山西省| 友谊县|