欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2018年10月16日 09:22:08   投稿:lijiao  
這篇文章主要為大家詳細(xì)介紹了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)文章

最新評論