前言在近期的小程序開發(fā)中,有一個離線生成二維碼的需求。當(dāng)時想到了一些優(yōu)秀的前端開源庫 jquery-qrcode 和 node-qrcode,由于小程序中沒有DOM的概念,這些庫在小程序中并不適用。 所以,針對微信小程序的特點,封裝了 weapp.qrcode.js ,用于在小程序中快速生成二維碼。效果如下圖: 下面來介紹一下使用方法: 使用創(chuàng)建canvas標(biāo)簽先在 wxml 文件中,創(chuàng)建繪制的 canvas,并定義好 width, height, canvasId 。由于小程序沒有動態(tài)創(chuàng)建標(biāo)簽的api,所以這一步不能省略。 <canvas style="width: 200px; height: 200px;" canvas-id="myQrcode"></canvas> 調(diào)用繪制方法由于微信小程序不支持引入NPM包,可以將dist目錄下,weapp.qrcode.min.js 拷貝至項目中。 如果你的小程序使用了支持引入NPM包的框架,如 wepy , 也可以直接安裝 weapp-qrcode NPM包。 npm install weapp-qrcode --save 引入 js 文件后,調(diào)用 drawQrcode() 繪制二維碼。
import drawQrcode from 'weapp-qrcode'
// 或者,將 dist 目錄下,weapp.qrcode.min.js 復(fù)制到項目目錄中
// import drawQrcode from '../../utils/weapp.qrcode.min.js'
drawQrcode({
width: 200,
height: 200,
canvasId: 'myQrcode',
text: 'https://github.com/yingye'
}
API說明
原始文檔如果想更深入的了解二維碼的原理,推薦大家閱讀 二維碼的生成細節(jié)和原理 。 |