转载文章 动态生成二维码插件 jquery.qrcode.jsjavascript
jquery.qrcode.js是依赖jquery的,因此要先引入jquery再引入jquery.qrcode.jshtml
<script type='text/javascript' src='js/jquery.min.js'></script> <script type="text/javascript" src="js/jquery.qrcode.min.js"></script>
在页面上添加一个div标签,用于建立渲染区域java
<div id="qrcode"></div>
经过下面代码就能够生成一个默认256×256大小的二维码jquery
<script type="text/javascript"> jQuery('#qrcode').qrcode("http://www.cnblogs.com/HtmlCss3/"); </script>
怎么样?简单吧,今后让二维码信手拈来~canvas
若是想要改变它的大小、二维码颜色、背景色怎么办?不用着急,咱们能够经过配置来获得咱们想要的,接下来咱们就看一看它的配置:编码
jQuery("#qrcode").qrcode({ render: "canvas", // 渲染方式有table方式和canvas方式 width: 256, //默认宽度 height: 256, //默认高度 text: "http://www.cnblogs.com/HtmlCss3/", //二维码内容 typeNumber: -1, //计算模式通常默认为-1 correctLevel: 2, //二维码纠错级别 background: "#ffffff", //背景颜色 foreground: "#000000" //二维码颜色 });
jquery.qrcode.js二维码内容是不支持中文的,若是出现中文,结果就是一串乱码,这个主要是二者的编码方式不同所致使的,中文通常状况下是UTF-16格式,若是想要支持中文,那就把二维码内容统一改为UTF-8格式的,顺便贴一下转换的代码:spa
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: utf16to8("文字内容") //二维码内容
有时候呢领导可能会让你把本身公司的logo放上去,可是jquery.qrcode.js又不支持这种自定义logo,这时候肿么办呢?其实也很简单,在div里建立一个img利用定位很容易就能够搞定它了code