原文地址: https://blog.csdn.net/u011127019/article/details/51226104

1.qrcode其实是通过使用jQuery实现图形渲染,画图,支持canvas(HTML5)和table两种方式,

github源码地址:

https://github.com/jeromeetienne/jquery-qrcode

参数说明:

  1. render   : "canvas",//设置渲染方式
  2. width       : 256,     //设置宽度
  3. height      : 256,     //设置高度
  4. typeNumber  : -1,      //计算模式
  5. correctLevel    : QRErrorCorrectLevel.H,//纠错等级
  6. background      : "#ffffff",//背景颜色
  7. foreground      : "#000000" //前景颜色

2.使用实例:

插件引用

  1.  <script src="../Js/jquery-1.11.3.min.js"></script>
  2. <script src="../Js/jquery-qrcode-master/jquery.qrcode.min.js"></script>

简单实例1:

  1. <div id="code"></div>
  2. <script>
  3. //任意字符串 生成二维码
  4. //默认使用Canvas画图
  5. $('#code').qrcode('http://blog.csdn.net/u011127019');
  6. </script>

简单实例2:

  1. <div id="code"></div>
  2. <script>
  3. //table 模式兼容 IE低版本
  4. $('#code').qrcode({
  5. render: 'table',
  6. width: 100,
  7. height: 100,
  8. text: 'http://blog.csdn.net/u011127019'
  9. });

10. </script>

简单实例3(中文支持):

我们试验的时候发现不能识别中文内容的二维码,通过查找多方资料了解到,jquery-qrcode是采用charCodeAt()方式进行编码转换的。而这个方法默认会获取它的Unicode编码,如果有中文内容,在生成二维码前就要把字符串转换成UTF-8,然后再生成二维码。

  1. <div id="code"></div>
  2. <script>
  3. //如果内容中有中文,在生成二维码钱就要把字符串转换成utf-8
  4. function toUtf8(str) {
  5. var out, i, len, c;
  6. out = "";
  7. len = str.length;
  8. for (i = 0; i < len; i++) {
  9. c = str.charCodeAt(i);
  10. if ((c >= 0x0001) && (c <= 0x007F)) {
  11. out += str.charAt(i);
  12. } else if (c > 0x07FF) {
  13. out += String.fromCharCode(0xE0 | ((c >> 12) & 0x0F));
  14. out += String.fromCharCode(0x80 | ((c >> 6) & 0x3F));
  15. out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F));
  16. } else {
  17. out += String.fromCharCode(0xC0 | ((c >> 6) & 0x1F));
  18. out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F));
  19. }
  20. }
  21. return out;
  22. }
  23. $('#code').qrcode({
  24. text: toUtf8('我是tianma'),
  25. width: 150,
  26. height: 150
  27. });
  28. //就目前 微信/支付宝等 不识别其他颜色的二维码
  29. $('#code').qrcode({
  30. text: toUtf8('我是tianma'),
  31. width: 150,
  32. height: 150,
  33. background: '#f00',
  34. foreground: '#0f0'
  35. });

38. </script>

实例4:

  1. //text 属性的值长度不能太长,最大字节数 10208
  2. //text 字符串太长 微信/支付宝等扫一扫无法识别,微博识别内容更多
  3. //微博扫一扫:大约200 字以内,微信扫一扫:大约 160字以内,支付宝扫一扫:大约130字符以内
  4. $('#code').qrcode({
  5. text: toUtf8('SignalR 是 ASP.NET 团队正在开发的一个 Microsoft .NET Framework 库和 jQuery 插件,可能包括在以后版本的 ASP.NET 平台中。 它提供了一些前景极为光明的功能,而这些功能正是,并且是越来越多的,当前不曾具有的,'),
  6. width: 150,
  7. height: 150
  8. });

实例5,将生成的二维码转换成图片格式:

  1. <div id="divOne"></div>
  2. <img id='imgOne'  style='border:1px solid red;'/>
  3. <script>
  4. //默认使用Canvas生成,并显示到图片
  5. var qrcode= $('#divOne').qrcode('http://www.gongjuji.net/').hide();
  6. var canvas=qrcode.find('canvas').get(0);
  7. $('#imgOne').attr('src',canvas.toDataURL('image/jpg'))
  8. </script>

显示结果:

实例6,在当前的图片上添加文字或logo处理:

  1. //默认使用Canvas画图
  2. var qrcode = $('#code').qrcode({
  3. text: '@url',
  4. width: 400,
  5. height: 400
  6. }).hide();
  7. //添加文字
  8. var text = "测试文字内容";//设置文字内容
  9. var canvas = qrcode.find('canvas').get(0);
  10. var oldCtx = canvas.getContext('2d');
  11. var imgCanvas = document.getElementById('imgCanvas');
  12. var ctx = imgCanvas.getContext('2d');
  13. ctx.fillStyle = 'white';
  14. ctx.fillRect(0,0,imgCanvas.width,imgCanvas.height);
  15. ctx.putImageData(oldCtx.getImageData(0, 0, canvas.width, canvas.height), 0, 0);
  16. ctx.fillStyle = 'red';
  17. ctx.strokStyle = 'rgb(1,1,0)';
  18. //ctx.stroke = 3;
  19. ctx.textBaseline = 'middle';
  20. ctx.textAlign = 'center';
  21. ctx.font = 'bolder 30px Helvetica';
  22. ctx.fillText(text, imgCanvas.width / 2, imgCanvas.height - 20);
  23. ctx.strokeText(text, imgCanvas.width / 2, imgCanvas.height - 20);
  24. imgCanvas.style.display = 'none';
  25. $('#imgCode').attr('src', imgCanvas.toDataURL('image/png')).css({
  26. maxWidth:300
  27. });

转: jquery.qrcode.js生成二维码插件&转成图片格式的更多相关文章

  1. 使用jquery.qrcode.js生成二维码

    通常生成二维码的方式有两种:第一种是java代码的形式,第二种是通过Js方式. 在这里我做个记录,用js生成二维码,可以在官网下载源码:http://jeromeetienne.github.io/j ...

  2. jquery.qrcode.js生成二维码(前端生成二维码)

    官网地址:http://jeromeetienne.github.io/jquery-qrcode/ 第一步引入插件: <script type='text/javascript' src='h ...

  3. jquery.qrcode.js 生成二维码并支持中文的方法

    GitHub地址: https://github.com/jeromeetienne/jquery-qrcode <div class="QR"></div> ...

  4. jquery.qrcode.js生成二维码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. js生成二维码并保存成图片下载

    我这里使用是jQuery,和jquery.qrcode.js,需要的可以自己找链接下载.示例代码仅做参考 html代码: <a id="downloadLink">&l ...

  6. QRCode.js生成二维码

    QRCode的GitHub地址: https://github.com/KeeeX/qrcodejs 该版本解决了主版本(https://github.com/davidshimjs/qrcodejs ...

  7. qrcode.js生成二维码因字符串过长而报错

    前端使用qrcode.js生成二维码的时候.有时候是会出现 qrcode length overflow (1632>1056) 目前使用的有效的解决办法是重新下载新版的qrcode.js 下载 ...

  8. 利用vcard和qrcode.js生成二维码导入联系人

    vCard是一种容许交换个人信息的数据规范,vCard数据格式的标识符是VCARD,vCard数据格式行是: 类型 [;参数]:值,具体的介绍百度都有,我们可以通过vcard来进行通讯录的保存,名片的 ...

  9. 【QRcode二维码】:使用JS前端插件QRcode.js生成二维码

    1.先简单说一下jquery-qrcode,这个开源的三方库(可以从https://github.com/jeromeetienne/jquery-qrcode 获取), qrcode.js 是实现二 ...

随机推荐

  1. 使用SecureCRT软件运维的配置习惯

    使用 SecureCRT 软件运维的配置习惯 作者:Eric 微信:loveoracle11g 选项--->全局选项 配置文件存放路径 默认CRT配置的配置文件在C盘 常规--->默认会话 ...

  2. pandas函数get_dummies的坑

    转载:https://blog.csdn.net/mvpboss1004/article/details/79188190 pandas中的get_dummies得到的one-hot编码数据类型是ui ...

  3. 第6章 静态路由和动态路由(3)_RIP动态路由协议

    5. RIP动态路由协议 5.1 RIP协议(Routing Information Protocol) (1)是一个距离矢量路由选择协议.选择最佳路径的标准是跳数,如果到达目标网络经过的路由器最少, ...

  4. C# 自己动手实现Spy++(一)

    因为项目要用到获取其他程序的标题,就想到了用Spy++,但是它是一个工具,并没有C#的源代码,所以就想探索下他的原理,网上搜索了下spy++的源代码,找到了一篇:http://blog.csdn.ne ...

  5. MySQL--局域网、外网访问MySQL

    一.局域网.外网访问 1. 打开CMD,导航到当前MySQL的bin路径,如下图: 2. 访问MySQL:输入MySQL -u root -p,点击Enter键,即可看到密码输入框: 输入密码,点需E ...

  6. Java 11 - Java String类

    Java String类 字符串广泛应用在Java编程中,在Java中字符串属于对象,Java提供了String类来创建和操作字符串. 创建字符串 创建字符串最简单的方式如下: String gree ...

  7. 编码,基本数据类型,str索引和切片,for循环

    1. 编码 1. 最早的计算机编码是ASCII. 美国人创建的. 包含了英文字母(大写字母, 小写字母). 数字, 标点等特殊字符!@#$% 128个码位 2**7 在此基础上加了一位 2**8 8位 ...

  8. python学习笔记_week6_面向对象

    面向对象 介绍(特性(class.object--->封装.继承,多态)).--->世界万物,皆可分类:世界万物,皆可对象 只要是对象,就肯定属于某种品类:只要是对象,就肯定有属性 你是上 ...

  9. hdfs standby namenode checkpoint 的一些参数

    dfs.namenode.checkpoint.period --两次检查点创建之间的固定时间间隔,默认3600,即1小时.所以去ann snn 看到的fsimage 相隔1个小时. dfs.name ...

  10. dbcp 连接池参数说明

    参考: http://commons.apache.org/proper/commons-dbcp/configuration.html https://www.cnblogs.com/happySm ...