视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
JS代码生成二维码实例分享
2020-11-27 20:01:22 责编:小采
文档


关于二维码的生成,有很多方法,本文主要给大家分享了用11行简单的JS代码制作出二维码生成的简单功能,希望能帮助到大家。

HTML代码:

<img style="display: none" id="qrcode" data-width="100" data-height="100" data-url="https://www.baidu.com/">

相关JS代码:

/**
 * 生成二维码
 * data-width={宽度}
 * data-height={高度}
 * data-url={链接}
 * @param $ele
 */
 var generatorQRCODE = function ($ele) {
 $ele.hide();
 var params = $ele.data();
 if(!params['width'] || !params['height'] || !params['url']){
 console.log('生成二维码参数错误');
 return false;
 }
 var image = new Image();
 var imageUrl = "http://pan.baidu.com/share/qrcode?w=" + params['width'] + "&h=" + params['height'] + "&url=" + params['url'] + "";
 image.src = imageUrl;
 $ele.attr('src', imageUrl);
 $ele.show();
 };
 
 generatorQRCODE($("#qrcode"));

再给大家分享一下其他生成二维码的案例:

使用jquery.qrcode生成二维码

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

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

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

<p id="code"></p>

3、调用qrcode插件。支持canvas和table两种方式进行图片渲染

canvas方式:

$('#code').qrcode("http://www.baidu.com"); //任意字符串

table方式:

$("#code").qrcode({ 
 render: "table", //table方式 
 width: 200, //宽度 
 height:200, //高度 
 text: "www.helloweba.com" //任意内容 
});

4、如果生成的二维码内容包含文字,需要把字符串转换成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; 
}

在生成的时候调用转化方法:

var str = toUtf8("字符串测试!"); 
$('#code').qrcode(str);

二、在Vue-cli项目中动态生成二维码

1、引入qrcode--------npm install qrcode

2、在main.js中引入

import QRCode from 'qrcode' //定义生成二维码组件

3、在需要使用到生成二维码的组件中引入

import QRCode from 'qrcode' //引入生成二维码组件

4、在HTML中定义生成的位置,注意添加样式

<template>
 <p id="query">
 <h1>二维码:</h1>
 <canvas id="canvas"></canvas>
 </p>

</template>
#canvas{
 width: 80%!important;
 height: auto!important;
 }

5、在js中定义生成二维码的方法并调用

//动态生成二维码
 useqrcode(){ //生成的二维码内容,可以添加变量    this.QueryDetail='http://www.kspxzx.com/#/guard'+"?unique_code="+this.QueryDetail;var canvas = document.getElementById('canvas')
 QRCode.toCanvas(canvas, this.QueryDetail, function (error) {
 if (error) console.error(error)
 console.log('success!');
 })
 }

下载本文
显示全文
专题