常见问题当前位置:万彩娱乐平台 > 常见问题 > >

使用jQuery.Qrcode插件在客户端动态生成二维码并添

  

[jquery,qrcode,二维码,qrcode,二维码]使用jQuery.Qrcode插件在客户端动态生成二维码并添加自定义Logo

  

0 Jquery.Qrcode简介  
  
  

  

Jquery.Qrcode.js是一个在浏览器端基于Jquery动态生成二维码的插件,支持Canvas和Table两种渲染方式,它的优点是在客户端动态生成,减轻了服务端压力,尤其是在大量使用二维码的系统中。Jquery.Qrcode主要包括以下参数设置:  

  

?render 定义二维码的渲染方式,有table和canvas两种渲染方式  

  

?width 定义二维码的宽度  
  

  

?height 定义二维码的高度  
  

  

?text 定义二维码内容  
  

  

?typeNumber 二维码的计算模式 一般默认为-1  
  

  

?correctLevel 二维码的纠错级别  
  

  

?background 定义二维码的背景颜色  
  

  

?foreground 定义二维码的前景色  
  

  

1 Jquery.Qrcode基本使用  
  
  

  

1.0 添加相关引用  
  

  

Jquery.Qrcode仅仅依赖于Jquery,所以我们只需要添加Jquery及Jquery.Qrcode的引用即可。

  
  

  
  
  
  
  

1.1 添加渲染区域元素  
  

  

Jquery.Qrcode使用div元素作为渲染的目标区域,在页面上添加一个div标签。

  
  

  
  
  
  
  
  

1.2 二维码生成  
  

  
  
  $("#qrCodeDiv").qrcode({  render: "canvas", // 渲染方式有table方式(IE兼容)和canvas方式  width: 260, //宽度  height: 260, //高度  text: "", //内容  typeNumber: -1,//计算模式  correctLevel: 2,//二维码纠错级别  background: "#ffffff",//背景颜色  foreground: "#000000" //二维码颜色  });
  
  

二维码生成如下  
  

  

  

  

2 Jquery.Qrcode对中文字符的支持  
  
  

  

默认的Jquery.Qrcode是不支持中文编码的,上面我们如果将text的内容设置为中文字符串,生成二维码并扫描后会发现结果是乱码。这是因为jquery.qrcode采用 charCodeAt() 方式进行编码转换,默认采用UTF-8方式编码,而针对中文一般情况下是采用UTF-16编码实现,这样就会导致乱码的出现,解决方案就是在二维码编码前,将二维码的内容字符串转换成UTF-8格式,js转换方法如下。

  
  

  
  
  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;  };
  
  

生成二维码时,将转码后的结果作为text的值即可  
万彩娱乐注册  

  
  
  $("#qrCodeDiv").qrcode({  render: "canvas", // 渲染方式有table方式(IE兼容)和canvas方式  width: 260, //宽度  height: 260, //高度  text: utf16to8("汉字内容的二维码"), //内容  typeNumber: -1,//计算模式  correctLevel: 2,//二维码纠错级别  background: "#ffffff",//背景颜色  foreground: "#000000" //二维码颜色  });
  
  

3 Jquery.Qrcode添加自定义Logo图片  
  
  

  

给二维码添加一个自定义的logo,会让你的二维码看上去更专业,默认的Jquery.Qrcode是不支持添加自定义Logo的,这里比较简单的实现方案就是,针对每个二维码添加一个img标签,让img在二维码区域相对居中显示即可。

  
  

  
  
  
  
  

控制img标签的位置  
  

  
  
  var margin = ($("#qrCodeDiv").height() - $("#qrCodeIco").height()) / 2; //控制Logo图标的位置  $("#qrCodeIco").css("margin", margin);
  
  

最终结果如下  
  

  

  

  

Jquery.Qrcode下载  

  

  

(责任编辑:admin)

上一篇:万彩娱乐注册Jquery 动态生成表格示例代码

下一篇:jquery取子节点及当前节点属性值的方法

推荐内容

客户服务热线

010-400-12345

在线客服