jQuery生成二维码

 

一、简要介绍

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

  1、github源码地址:https://github.com/jeromeetienne/jquery-qrcode

  2、参数说明

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

 

二、准备工作

  1、下载jQuery生成二维码的插件

  资源链接:百度云:链接:https://pan.baidu.com/s/1o9oBB54 密码:h4x8

  2、每个js文件均引入插件

<script type="text/javascript" src="js/jquery-1.11.3.min.js"></script>
<script type="text/javascript" src="js/jquery.qrcode.min.js"></script>

 

三、使用实例

  实例1:

<div id="code"></div>
<script type="text/javascript">
    //任意字符串 生成二维码
    //默认使用Canvas画图  
    $("#code").qrcode("https://hao.360.cn/?src=bm");
</script>

  效果图:

  实例2

复制代码
<div id="code"></div>
<script type="text/javascript">
        //table 模式兼容 IE低版本
        $("#code").qrcode({
        render:'table',
        width:"100",
        height: "100",
        text:"https://hao.360.cn/?src=bm"
    });
</script>
复制代码

  效果图:

  实例3(中文支持):

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

复制代码
  <div id="code"></div>
    <script>
        //如果内容中有中文,在生成二维码钱就要把字符串转换成utf-8
        function toUtf8(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;
        }

        $('#code').qrcode({
            text: toUtf8('我在学jQuery生成二维码'),
            width: 150,
            height: 150
        });
    </script>
复制代码

  效果图:

  实例4:

复制代码
<div id="code"></div>
    <script>
        //如果内容中有中文,在生成二维码钱就要把字符串转换成utf-8
        function toUtf8(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;
        }

        $('#code').qrcode({
            text: toUtf8('我在学jQuery生成二维码'),
            width: 150,
            height: 150,
            background: '#f00',  
            foreground: '#0f0' 
        });
    </script>
复制代码

  效果图:

  实例5:

复制代码
<div id="code"></div>
    <script>
        //如果内容中有中文,在生成二维码钱就要把字符串转换成utf-8
        function toUtf8(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 属性的值长度不能太长,最大字节数 10208  
        //text 字符串太长 微信/支付宝等扫一扫无法识别,微博识别内容更多  
        //微博扫一扫:大约200 字以内,微信扫一扫:大约 160字以内,支付宝扫一扫:大约130字符以内  
        $('#code').qrcode({  
            text: toUtf8('SignalR 是 ASP.NET 团队正在开发的一个 Microsoft .NET Framework 库和 jQuery 插件,可能包括在以后版本的 ASP.NET 平台中。 它提供了一些前景极为光明的功能,而这些功能正是,并且是越来越多的,当前不曾具有的,'),  
            width: 150,  
            height: 150  
        });  
    </script>
复制代码

  效果图:

  实例6:

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

  效果图:

 

posted @   沧海一粟hr  阅读(759)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
点击右上角即可分享
微信分享提示