解决qrcode.js生成二维码时必须定义一个空div的问题


Posted in Javascript onJuly 09, 2020

根据qrcode的文档说明:https://github.com/davidshimjs/qrcodejs

<div id="qrcode"></div>
<script type="text/javascript">
new QRCode(document.getElementById("qrcode"), "sample text");
// or 
new QRCode(document.getElementById("qrcode"), {
 text: 'sample text',
 width: 200,
 height: 200,
 colorDark: "#000000",
 colorLight: "#ffffff",
 correctLevel: QRCode.CorrectLevel.H
});

要有一个元素存放二维码,

可以看到这个div中被追加了canvas,img两个标签。

但是我想不想创建这个div啊。然后我就找到了node-qrcode

他有两种用法:

<html>
 <body>
 <canvas id="canvas"></canvas>
 <script src="bundle.js"></script> 
 </body>
</html>
<script>
 var QRCode = require('qrcode')
 var canvas = document.getElementById('canvas')
 QRCode.toCanvas(canvas, 'sample text', function (error) {
  if (error) console.error(error)
  console.log('success!');
 })
</script>

很显然这种和前面那个一样,需要先创建一个标签。

var QRCode = require('qrcode')
 
QRCode.toDataURL('I am a pony!', function (err, url) {
 console.log(url)
})

终于找到我想要的了,不过,这里的url是base64,如果二维码过大的话,使用base64进行图片渲染,会导致浏览器崩溃,这个问题后面解决。

那么问题又来了,这个node-qrcode只能用在vue中使用(不能直接在浏览器运行,需要特殊处理),如果想直接使用(或在vue中使用cdn)必须用第一种模式。

这问题有绕回来了。

暂时没有好的方案。自己二次优化一下吧。

既然第一种方案里,有一个img标切,是不是可以读取图片流,然后自己处理?

var div = document.createElement('div');
var size = 200;
var padding = 20;
var bg = '#ffffff';
new QRCode(div, {
 text: val,
 width: size,
 height: size,
 colorDark: "#000000",
 colorLight: bg,
 correctLevel: QRCode.CorrectLevel.H
});
console.log(div.querySelector('img').src);

发现是空的''.
根据以往经验,这里的图片,可能需要时间来渲染?

div.querySelector('img').addEventListener('load', (event) => {
 var img = event.target;
 console.log(img.src); 
})

果然拿到了base64地址。
到此,就已经解决所有问题,剩下的,就是自己画个二维码了(这种方法生成的二维码,没有边距留白,非常丑)

// https://github.com/davidshimjs/qrcodejs
export default {
 imageBase64ToBlob(urlData, type = 'image/jpeg') {
  var ab = null;
  try {
   var arr = urlData.split(',')
   var mime = arr[0].match(/:(.*?);/)[1] || type;
   // 去掉url的头,并转化为byte
   var bytes = window.atob(arr[1]);
   // 处理异常,将ascii码小于0的转换为大于0
   ab = new ArrayBuffer(bytes.length);
   // 生成视图(直接针对内存):8位无符号整数,长度1个字节
   var ia = new Uint8Array(ab);

   for (var i = 0; i < bytes.length; i++) {
    ia[i] = bytes.charCodeAt(i);
   }

   return new Blob([ab], {
    type: mime
   });
  } catch (e) {
   ab = new ArrayBuffer(0);
   return new Blob([ab], {
    type: type,
   });
  }
 },
 createQr(val, back) {
  var div = document.createElement('div');
  var size = 200;
  var padding = 20;
  var bg = '#ffffff';
  new QRCode(div, {
   text: val,
   width: size,
   height: size,
   colorDark: "#000000",
   colorLight: bg,
   correctLevel: QRCode.CorrectLevel.H
  });
  var canvas = div.querySelector('canvas');
  div.querySelector('img').addEventListener('load', (event) => {
   var img = event.target;
   var ctx = canvas.getContext('2d');
   ctx.fillStyle = bg;
   ctx.fillRect(0, 0, size, size);
   // ctx.clearRect(0, 0, size, size);
   ctx.drawImage(img, 0, 0, img.width, img.height, padding, padding, size - 2 * padding, size - 2 * padding);
   let url = canvas.toDataURL();
   back(URL.createObjectURL(this.imageBase64ToBlob(url)))
  })
 }
}

到此这篇关于解决qrcode.js生成二维码时必须定义一个空div的问题的文章就介绍到这了,更多相关qrcode.js二维码定义一个空div内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
一些易混淆且不常用的属性,希望有用
Jan 29 Javascript
网页开发中的容易忽略的问题 javascript HTML中的table
Apr 15 Javascript
JS面向对象编程详解
Mar 06 Javascript
详解vue-cli中配置sass
Jun 21 Javascript
详解layui中的树形关于取值传值问题
Jan 16 Javascript
js经验分享 JavaScript反调试技巧
Mar 10 Javascript
vue中子组件传递数据给父组件的讲解
Jan 27 Javascript
JavaScript偏函数与柯里化实例详解
Mar 27 Javascript
小程序瀑布流组件实现翻页与图片懒加载
May 19 Javascript
node+vue实现文件上传功能
May 28 Javascript
Antd下拉选择,自动匹配功能的实现
Oct 24 Javascript
React forwardRef的使用方法及注意点
Jun 13 Javascript
Electron 打包问题:electron-builder 下载各种依赖出错(推荐)
Jul 09 #Javascript
jQuery实现B2B网站后台管理系统侧导航
Jul 08 #jQuery
ssm+vue前后端分离框架整合实现(附源码)
Jul 08 #Javascript
Vue作用域插槽实现方法及作用详解
Jul 08 #Javascript
Vue Render函数创建DOM节点代码实例
Jul 08 #Javascript
实例讲解React 组件生命周期
Jul 08 #Javascript
详细分析React 表单与事件
Jul 08 #Javascript
You might like
坏狼的PHP学习教程之第2天
2008/06/15 PHP
无法在发生错误时创建会话,请检查 PHP 或网站服务器日志,并正确配置 PHP 安装最快的解决办法
2010/08/01 PHP
Zend Framework 2.0事件管理器(The EventManager)入门教程
2014/08/11 PHP
php通过array_shift()函数移除数组第一个元素的方法
2015/03/18 PHP
PHP下使用mysqli的函数连接mysql出现warning: mysqli::real_connect(): (hy000/1040): ...
2016/02/14 PHP
jquery 插件开发方法小结
2009/10/23 Javascript
Javascript学习笔记9 prototype封装继承
2010/01/11 Javascript
JavaScript数字和字符串转换示例
2014/03/26 Javascript
IE6-8中Date不支持toISOString的修复方法
2014/05/04 Javascript
jquery图片切换实例分析
2015/04/15 Javascript
Bootstrap风格的WPF样式
2016/12/07 Javascript
JavaScript观察者模式(publish/subscribe)原理与实现方法
2017/03/30 Javascript
解决vue2.0动态绑定图片src属性值初始化时报错的问题
2018/03/14 Javascript
vue translate peoject实现在线翻译功能【新手必看】
2018/06/07 Javascript
详解Eslint 配置及规则说明
2018/09/10 Javascript
JavaScript实现表单注册、表单验证、运算符功能
2018/10/15 Javascript
ES6数组与对象的解构赋值详解
2019/06/14 Javascript
javascript设计模式 ? 命令模式原理与用法实例分析
2020/04/20 Javascript
Python实现自动登录百度空间的方法
2017/06/10 Python
基于python中pygame模块的Linux下安装过程(详解)
2017/11/09 Python
Python模块的加载讲解
2019/01/15 Python
Python处理session的方法整理
2019/08/29 Python
python的faker库用法
2019/11/28 Python
基于Python实现扑克牌面试题
2019/12/11 Python
PyTorch中model.zero_grad()和optimizer.zero_grad()用法
2020/06/24 Python
Python 打印自己设计的字体的实例讲解
2021/01/04 Python
Perfumetrader荷兰:香水、化妆品和护肤品在线商店
2017/09/15 全球购物
生物有机护肤品:Aurelia Probiotic Skincare
2018/01/31 全球购物
少先队学雷锋活动月总结
2014/03/09 职场文书
土地转让协议书范本
2014/04/15 职场文书
初中班主任评语
2014/04/24 职场文书
2014年群众路线教育实践活动整改措施
2014/09/24 职场文书
领导班子个人对照检查剖析材料
2014/09/29 职场文书
2014年妇女工作总结
2014/12/06 职场文书
2014年心理健康教育工作总结
2014/12/06 职场文书
特种设备安全管理制度
2015/08/06 职场文书