<script src="~/Content/js/jquery-2.1.4.min.js"></script><script src="~/Content/js/jquery.qrcode.min.js"></script>1.1 添加渲染区域元素
<div id="qrCodeDiv"></div>1.2 二维码生成
$("#qrCodeDiv").qrcode({render: "canvas", // 渲染方式有table方式(IE兼容)和canvas方式width: 260, //宽度height: 260, //高度text: "www.baidu.com", //内容typeNumber: -1,//计算模式correctLevel: 2,//二维码纠错级别background: "#ffffff",//背景颜色foreground: "#000000" //二维码颜色});二维码生成如下
2 Jquery.Qrcode对中文字符的支持
默认的Jquery.Qrcode是不支持中文编码的,上面我们如果将text的内容设置为中文字符串,生成二维码并扫描后会发现结果是乱码。这是因为jquery.qrcode采用 charCodeAt() 方式进行编码转换,默认采用UTF-8方式编码,而针对中文一般情况下是采用UTF-16编码实现,这样就会导致乱码的出现,解决方案就是在二维码编码前,将二维码的内容字符串转换成UTF-8格式,js转换方法如下。
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的值即可
$("#qrCodeDiv").qrcode({render: "canvas", // 渲染方式有table方式(IE兼容)和canvas方式width: 260, //宽度height: 260, //高度text: utf16to8("汉字内容的二维码"), //内容typeNumber: -1,//计算模式correctLevel: 2,//二维码纠错级别background: "#ffffff",//背景颜色foreground: "#000000" //二维码颜色});3 Jquery.Qrcode添加自定义Logo图片
<img id="qrCodeIco" src="~/images/logo.png" style="position: absolute;width: 30px; height: 30px;" />控制img标签的位置
var margin = ($("#qrCodeDiv").height() - $("#qrCodeIco").height()) / 2; //控制Logo图标的位置$("#qrCodeIco").css("margin", margin);最终结果如下
Jquery.Qrcode下载
以上所述是小编给大家介绍的使用jQuery.Qrcode插件在客户端动态生成二维码并添加自定义Logo,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!