微信小程序中生成二维码工具:weapp.qrcode.js
2018-02-07 20:49 阅读(305)

前言

在近期的小程序开发中,有一个离线生成二维码的需求。当时想到了一些优秀的前端开源库 jquery-qrcode 和 node-qrcode,由于小程序中没有DOM的概念,这些库在小程序中并不适用。

所以,针对微信小程序的特点,封装了 weapp.qrcode.js ,用于在小程序中快速生成二维码。效果如下图:

下面来介绍一下使用方法:

使用

创建canvas标签

先在 wxml 文件中,创建绘制的 canvas,并定义好 widthheightcanvasId 。由于小程序没有动态创建标签的api,所以这一步不能省略。

<canvas style="width: 200px; height: 200px;" canvas-id="myQrcode"></canvas>

调用绘制方法

由于微信小程序不支持引入NPM包,可以将dist目录下,weapp.qrcode.min.js 拷贝至项目中。

如果你的小程序使用了支持引入NPM包的框架,如 wepy , 也可以直接安装 weapp-qrcode NPM包。

npm install weapp-qrcode --save

引入 js 文件后,调用 drawQrcode() 绘制二维码。

import drawQrcode from 'weapp-qrcode'
// 或者,将 dist 目录下,weapp.qrcode.min.js 复制到项目目录中
// import drawQrcode from '../../utils/weapp.qrcode.min.js'
drawQrcode({  
    width: 200,  
    height: 200,  
    canvasId: 'myQrcode',  
    text: 'https://github.com/yingye'
  }

API说明

参数说明示例
width必须,二维码宽度,与canvaswidth保持一致200
height必须,二维码高度,与canvasheight保持一致200
canvasId必须,绘制的canvasId'myQrcode'
text必须,二维码内容'https://github.com/yingye'
typeNumber非必须,二维码的计算模式,默认值-18
correctLevel非必须,二维码纠错级别,默认值为高级,取值:{ L: 1, M: 0, Q: 3, H: 2 }1
background非必须,二维码背景颜色,默认值白色'#ffffff'
foreground非必须,二维码前景色,默认值黑色'#000000'

如果想更深入的了解二维码的原理,推荐大家阅读 二维码的生成细节和原理 。

原始文档

https://github.com/yingye/wea... ,如果觉得还不错,记得给个star奥~



作者:yingye