Jquery.Qrcode 在客户端动态生成二维码并添加自定义Logo

发布于 2019年06月29日 10:24:10 - 技术分享 - JavaScript - jQuery

Jquery.Qrcode.js是一个在浏览器端基于Jquery动态生成二维码的插件,支持Canvas和Table两种渲染方式,它的优点是在客户端动态生成,减轻了服务端压力,尤其是在大量使用二维码的系统中。

Jquery.Qrcode主要包括以下参数设置:

  • render 定义二维码的渲染方式,有table和canvas两种渲染方式
  • width 定义二维码的宽度
  • height 定义二维码的高度
  • text 定义二维码内容
  • typeNumber 二维码的计算模式 一般默认为-1
  • correctLevel 二维码的纠错级别
  • background 定义二维码的背景颜色
  • foreground 定义二维码的前景色

1.如何使用

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

Jquery.Qrcode仅仅依赖于Jquery,所以我们只需要添加Jquery及Jquery.Qrcode的引用即可。

<script src="~/Content/js/jquery-2.1.4.min.js"></script>
<script src="~/Content/js/jquery.qrcode.min.js"></script>

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

Jquery.Qrcode使用div元素作为渲染的目标区域,在页面上添加一个div标签

<div id="qrCodeDiv">
</div>

3.调用qrcode插件

qrcode支持canvas和table两种方式进行图片渲染,默认使用canvas方式,效率最高,当然要浏览器支持html5。直接调用如下:

默认方式:

$('#qrCodeDiv').qrcode("http://www.xdy.me"); //任意字符串

自定义方式:

$("#qrCodeDiv").qrcode({
   render: "canvas", // 渲染方式有table方式(IE兼容)和canvas方式
    width: 260, //宽度
    height: 260, //高度
    text: "www.xdy.me", //内容
    typeNumber: -1,//计算模式
    correctLevel: 2,//二维码纠错级别
    background: "#ffffff",//背景颜色
    foreground: "#000000"  //二维码颜色
});

二维码生成如下:

2.识别中文

默认的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.添加自定义Logo图片

给二维码添加一个自定义的logo,会让你的二维码看上去更专业,默认的Jquery.Qrcode是不支持添加自定义Logo的,这里比较简单的实现方案就是,针对每个二维码添加一个img标签,让img在二维码区域相对居中显示即可。

<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);

最终结果如下

网盘地址 密码:

解压密码:http://xdy.me | www.xdy.me

本站所有软件仅供学习使用,请在24小时内删除,本站不承担任何相关责任!

转载声明:本站文章无特别说明,皆为原创,版权所有,转载请注明:Dy大叔的日常

转载自 Jquery.Qrcode 在客户端动态生成二维码并添加自定义Logo | XDY.ME@Dy大叔的日常

XDY.ME@Dy大叔的日常