生成二维码的两种方式 - 养猫者

时间:2024-02-18 14:06:42

生成二维码的两种方式

  利用qrcode生成二维码,(qrcode矩形二维码符号)

  基于jquery的二维码生成插件qrcode,在页面中调用该插件就能生成对应的二维码。qrcode其实是通过使用jQuery实现图形渲染,画图,支持canvas(HTML5)和table两种方式:

 

使用插件时

1、首先在页面中加入jquery库文件和qrcode插件。

<script type="text/javascript" src="jquery.js"></script> 
<script type="text/javascript" src="jquery.qrcode.min.js"></script> 

2、在页面中需要显示二维码的地方加入以下代码:

<div id="code"></div> 

3、调用qrcode插件。

qrcode支持canvas和table两种方式进行图片渲染,默认使用canvas方式,效率最高,当然要浏览器支持html5。直接调用如下:

$(\'#code\').qrcode("http://www.helloweba.com"); //任意字符串 

您也可以通过以下方式调用:

$("#code").qrcode(
    render: "table", //table方式 
    width: 200, //宽度 
    height:200, //高度 
    text: "www.helloweba.com" //任意内容 
}); 

这样就可以在页面中直接生成一个二维码,你可以用手机“扫一扫”功能读取二维码信息。

识别中文:试验的时候发现不能识别中文内容的二维码,通过查找多方资料了解到,jquery-qrcode是采用charCodeAt()方式进行编码转换的。而这个方法默认会获取它的Unicode编码,如果有中文内容,在生成二维码前就要把字符串转换成UTF-8,然后再生成二维码。您可以通过以下函数来转换中文字符串:

function toUtf8(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;    

以下示例:

var str = toUtf8("钓鱼岛是中国的!"); 
$(\'#code\').qrcode(str); 


1、页面元素:地址输入框,canvas方式的显示div,table方式的显示div

 

[html] view plain copy
 
  1. <input id="urlIn" placeholder="请输入网址">  
  2. <div class="qrCodeShow" id="canvas"></div>  
  3. <div class="qrCodeShow" id="table"></div>  

2、引入jquery支持及jquery.qrcode支持,这两个都比较好找

3、js控制二维码生成

 

[javascript] view plain copy
 
  1. $(function(){  
  2.         //获得焦点时添加url协议头http://  
  3.         $("#urlIn").focus(function(){  
  4.             $("#urlIn").val("http://");  
  5.         });  
  6.   
  7.         //输入框失去焦点时显示输入框值  
  8.         $("#urlIn").blur(function () {  
  9.             $("#canvas").empty();  
  10.             $("#table").empty();  
  11.   
  12.             var url = $("#urlIn").val();  
  13. //            alert(url)  
  14.             //canvas方式生成二维码(二维码是一张图片)  
  15.             $("#canvas").qrcode(url);  
  16.             //table方式生成二维码(二维码是由<table>标签的单元格填黑白框的方式形成)  
  17.             $("#table").qrcode({  
  18.                 render: "table",  
  19.                 width: 200,  
  20.                 height: 200,  
  21.                 text: url  
  22.             })  
  23.         })  
  24.   
  25.     })  

 

 

以上就是代码,实际效果如下:

 

说说两者的区别:看起来两者生成的二维码是一样的,移动设备扫码后验证有效。canvas方式只有一句代码,table则有各种设置相对代码多些。但实际生成的两个二维码并不相同。

通过页面元素审查我们能够发现,canvas方式生成的实际是一张图片,而table方式生成的则是由html的<table>标签通过控制细密的单元格背景色的黑白来组成的二维码,一个点就是一个单元格。canvas方式生成的可直接以图片格式保存,而table的不能。canvas的容易放大失真,table的不易失真。

实际应用就看需求了,只是需要显示name两者皆可,若需要利于保存,则canvas的较为方便。

 

这是学习二维码时搜到的资料,为了完成毕业设计。资料来源于:http://blog.csdn.net/zx0717zx/article/details/53379212