zoukankan      html  css  js  c++  java
  • 生成二维码的两种方式

      利用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方式 
         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.                  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




  • 相关阅读:
    数据结构和算法关系
    x轴滚动
    常用Python第三方库简介
    devgridContral
    第一次线程使用经验总结
    调取图片出现的的内存泄露,导致大红叉
    IEEE754 处理数据变换
    c# 基础任务1
    Python-常用第三方库
    C#高性能大容量SOCKET并发(八):通讯协议
  • 原文地址:https://www.cnblogs.com/hq123/p/6771329.html
Copyright © 2011-2022 走看看