使用jQuery.Qrcode插件在客户端动态生成二维码并添加自定义Logo


Posted in Javascript onSeptember 01, 2016

0 Jquery.Qrcode简介

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

•render 定义二维码的渲染方式,有table和canvas两种渲染方式

•width 定义二维码的宽度

•height 定义二维码的高度

•text 定义二维码内容

•typeNumber 二维码的计算模式 一般默认为-1

•correctLevel 二维码的纠错级别

•background 定义二维码的背景颜色

•foreground 定义二维码的前景色

1 Jquery.Qrcode基本使用

1.0 添加相关引用

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>

1.1 添加渲染区域元素

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

<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" //二维码颜色
});

二维码生成如下

使用jQuery.Qrcode插件在客户端动态生成二维码并添加自定义Logo

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图片

给二维码添加一个自定义的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);

最终结果如下

使用jQuery.Qrcode插件在客户端动态生成二维码并添加自定义Logo

以上所述是小编给大家介绍的使用jQuery.Qrcode插件在客户端动态生成二维码并添加自定义Logo,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
双击滚屏-常用推荐
Nov 29 Javascript
js判断游览器类型及版本号的代码
May 11 Javascript
判断复选框是否被选中的两种方法
Jun 04 Javascript
Bootstrap Fileinput文件上传组件用法详解
May 10 Javascript
js移动焦点到最后位置的简单方法
Nov 25 Javascript
phantomjs导出html到pdf的方法总结
Oct 19 Javascript
Vuejs实现购物车功能
Nov 05 Javascript
element-ui 表格数据时间格式化的方法
Aug 24 Javascript
vue写h5页面的方法总结
Feb 12 Javascript
Vue中this.$nextTick的作用及用法
Feb 04 Javascript
JavaScript console的使用方法实例分析
Apr 28 Javascript
24个ES6方法解决JS实际开发问题(小结)
May 31 Javascript
jQuery中的insertBefore(),insertAfter(),after(),before()区别介绍
Sep 01 #Javascript
AngularJs bootstrap搭载前台框架——准备工作
Sep 01 #Javascript
JS仿hao123导航页面图片轮播效果
Sep 01 #Javascript
javaScript如何跳出多重循环break、continue
Sep 01 #Javascript
AngularJs bootstrap详解及示例代码
Sep 01 #Javascript
JavaScript数据类型学习笔记分享
Sep 01 #Javascript
js实现文字超出部分用省略号代替实例代码
Sep 01 #Javascript
You might like
php IP转换整形(ip2long)的详解
2013/06/06 PHP
PHP学习笔记之字符串编码的转换和判断
2014/05/22 PHP
用JavaScript玩转游戏物理(一)运动学模拟与粒子系统
2010/06/19 Javascript
使用jQuery全局事件ajaxStart为特定请求实现提示效果的代码
2010/12/30 Javascript
原生js写的放大镜效果
2012/08/22 Javascript
Nodejs实现的一个简单udp广播服务器、客户端
2014/09/25 NodeJs
javascript实现playfair和hill密码算法
2014/12/07 Javascript
jQuery实现div拖拽效果实例分析
2016/02/20 Javascript
jQuery四种选择器使用及示例
2016/06/05 Javascript
jquery 实现回车登录详解及实例代码
2016/10/23 Javascript
ES6中Math对象新增的方法实例详解
2017/04/25 Javascript
jQuery简介_动力节点Java学院整理
2017/07/04 jQuery
vue2.0 better-scroll 实现移动端滑动的示例代码
2018/01/25 Javascript
解决vue项目nginx部署到非根目录下刷新空白的问题
2018/09/27 Javascript
jquery图片预览插件实现方法详解
2019/07/18 jQuery
javascript 模块依赖管理的本质深入详解
2020/04/30 Javascript
在实例中重学JavaScript事件循环
2020/12/03 Javascript
Python实现快速多线程ping的方法
2015/07/15 Python
Python爬虫框架Scrapy实战之批量抓取招聘信息
2015/08/07 Python
python opencv摄像头的简单应用
2019/06/06 Python
python 随机森林算法及其优化详解
2019/07/11 Python
python编写softmax函数、交叉熵函数实例
2020/06/11 Python
购买限量版收藏品、珠宝和礼品:Bradford Exchange
2016/09/23 全球购物
澳大利亚最好的在线时尚精品店:Princess Polly
2018/01/03 全球购物
Yummie官方网站:塑身衣和衣柜必需品
2019/10/29 全球购物
利用promise及参数解构封装ajax请求的方法
2021/03/24 Javascript
咖啡厅创业计划书范本
2014/01/22 职场文书
公务员综合考察材料
2014/02/01 职场文书
本科毕业自我鉴定
2014/03/20 职场文书
知识竞赛主持词
2014/03/26 职场文书
孝敬父母的演讲稿
2014/05/14 职场文书
幼儿园感恩节活动方案2014
2014/10/11 职场文书
区域经理岗位职责
2015/02/02 职场文书
基于Python实现的购物商城管理系统
2021/04/27 Python
python实现腾讯滑块验证码识别
2021/04/27 Python
Python中的min及返回最小值索引的操作
2021/05/10 Python