利用qrcode生成二维码,(qrcode矩形二维码符号)javascript
基于jquery的二维码生成插件qrcode,在页面中调用该插件就能生成对应的二维码。qrcode实际上是经过使用jQuery实现图形渲染,画图,支持canvas(HTML5)和table两种方式:html
使用插件时html5
一、首先在页面中加入jquery库文件和qrcode插件。java
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="jquery.qrcode.min.js"></script>
二、在页面中须要显示二维码的地方加入如下代码:jquery
<div id="code"></div>
三、调用qrcode插件。web
qrcode支持canvas和table两种方式进行图片渲染,默认使用canvas方式,效率最高,固然要浏览器支持html5。直接调用以下:canvas
$('#code').qrcode("http://www.helloweba.com"); //任意字符串
您也能够经过如下方式调用:浏览器
$("#code").qrcode({
render: "table", //table方式
width: 200, //宽度
height:200, //高度
text: "www.helloweba.com" //任意内容
});
这样就能够在页面中直接生成一个二维码,你能够用手机“扫一扫”功能读取二维码信息。函数
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);
一、页面元素:地址输入框,canvas方式的显示div,table方式的显示div
二、引入jquery支持及jquery.qrcode支持,这两个都比较好找
三、js控制二维码生成
以上就是代码,实际效果以下:
说说二者的区别:看起来二者生成的二维码是同样的,移动设备扫码后验证有效。canvas方式只有一句代码,table则有各类设置相对代码多些。但实际生成的两个二维码并不相同。
经过页面元素审查咱们可以发现,canvas方式生成的实际是一张图片,而table方式生成的则是由html的<table>标签经过控制细密的单元格背景色的黑白来组成的二维码,一个点就是一个单元格。canvas方式生成的可直接以图片格式保存,而table的不能。canvas的容易放大失真,table的不易失真。
实际应用就看需求了,只是须要显示name二者皆可,若须要利于保存,则canvas的较为方便。
这是学习二维码时搜到的资料,为了完成毕业设计。资料来源于:http://blog.csdn.net/zx0717zx/article/details/53379212