博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
生成二维码的两种方式
阅读量:6036 次
发布时间:2019-06-20

本文共 2370 字,大约阅读时间需要 7 分钟。

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

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

 

使用插件时

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

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

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] 
 
 
  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] 
 
 
  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

 

转载于:https://www.cnblogs.com/hq123/p/6771329.html

你可能感兴趣的文章
MySQL修改提示符
查看>>
《ELK Stack权威指南(第2版)》一3.6 Java日志
查看>>
C++流的streambuf详解及TCP流的实现
查看>>
《量化金融R语言初级教程》一2.5 协方差矩阵中的噪声
查看>>
mysql到elasticsearch数据迁移踩坑实践-Ali0th
查看>>
Python轻量级数据分析库DaPy
查看>>
beetl 和 shrio 结合
查看>>
相对/绝对路径,cd命令,mkdir/rmdir命令,rm命令
查看>>
tomcat中web.xml各配置项的意义
查看>>
Nodejs学习笔记(二):《node.js开发指南》代码中需要注意的几点
查看>>
Ztree异步加载自动展开节点
查看>>
反射操作公共成员变量
查看>>
Android热修复升级探索——代码修复冷启动方案
查看>>
学校宿舍的深夜之思考
查看>>
VB.NET 生成DBF文件
查看>>
编译安装nginx 1.9.15
查看>>
我的友情链接
查看>>
新的开始~~~
查看>>
字符串的扩展
查看>>
存储过程中调用webservice
查看>>