简要教程
qrious是一款基于HTML5 canvas的纯JS二维码生成插件。通过qrious.js可以快速生成各种二维码,你可以控制二维码的尺寸颜色,还可以将生成的二维码进行Base64编码。
安装
可以通过bower或npm来安装qrious.js二维码插件。
代码语言:javascript复制 $ npm install --save qrious
$ bower install --save qrious
引入JS
使用该二维码生成插件需要在页面中引入qrious.js文件。
代码语言:javascript复制<script type="text/javascript" src="js/qrious.js"></script>
HTML结构
使用一个<canvas>元素来作为二维码图片的容器。
代码语言:javascript复制<div class="htmleaf-container">
<header class="htmleaf-header">
<h1>基于canvas的纯JS二维码生成插件 <span>Pure JavaScript library for QR code generation using canvas</span></h1>
<div class="htmleaf-links">
<a class="htmleaf-icon icon-htmleaf-home-outline" href="http://www.zzfriend.com/" title="蚂蚁社区" target="_blank"><span> 蚂蚁社区</span></a>
<a class="htmleaf-icon icon-htmleaf-arrow-forward-outline" href="http://edu.zzfriend.com" title="蚂蚁社区教程" target="_blank"><span> 蚂蚁社区教程</span></a>
</div>
</header>
<main>
<section>
<img id="qrious">
<form autocomplete="off">
<label>
value
<input type="text" name="value" value="http://www.zzfriend.com/" spellcheck="false">
</label>
<label>
size
<input type="number" name="size" placeholder="100" min="100" max="1000" value="250">
</label>
<label>
level
<select name="level">
<option value="L">L - 7% damage</option>
<option value="M">M - 15% damage</option>
<option value="Q">Q - 25% damage</option>
<option value="H">H - 30% damage</option>
</select>
</label>
<label>
background
<input type="color" name="background" value="#ffffff">
</label>
<label>
foreground
<input type="color" name="foreground" value="#000000">
</label>
</form>
</section>
</main>
</div>
初始化插件
可以通过QRious()方法来实例化一个对象实例。
代码语言:javascript复制(function() {
const qr = new QRious({
element: document.getElementById('qr'),
value: 'http://www.zzfriend.com/'
})
})()
如果你在Node.js中使用,代码如下:
代码语言:javascript复制const express = require('express')
const QRious = require('qrious')
const app = express()
app.get('/qr', (req, res) => {
const qr = new QRious({ value: 'http://www.zzfriend.com/' })
res.end(new Buffer(qr.toDataURL(), 'base64'))
})
app.listen(3000)
配置参数
qrious.js二维码插件的可用配置参数如下:
例如:
代码语言:javascript复制const qr = new QRious()
qr.background = '#000'
qr.foreground = '#fff'
qr.level = 'H'
qr.size = 500
qr.value = 'http://www.zzfriend.com/'
或者在构造函数中传入:
代码语言:javascript复制const qr = new QRious({
background: '#000',
foreground: '#fff',
level: 'H',
size: 500,
value: 'http://www.zzfriend.com/'
})
你可以在element参数中设置用于生成二维码的DOM元素。DOM元素必须是<canvas>元素或<img>元素。
代码语言:javascript复制const qr = new QRious({
element: document.querySelector('canvas'),
value: 'http://www.zzfriend.com/'
})
qr.canvas.parentNode.appendChild(qr.image)
toDataURL([mime])方法
通过toDataURL([mime])方法可以生成二维码的Base64编码数据的URI。如果你没有指定MIME Type,会使用默认值作为mime类型。
代码语言:javascript复制const qr = new QRious({
value: 'http://www.zzfriend.com/'
})
console.log(qr.toDataURL())
//=> "data:image/png;base64,iVBOR...AIpqDnseH86KAAAAAElFTkSuQmCC"
console.log(qr.toDataURL('image/jpeg'))
//=> "data:image/jpeg;base64,/9j/...xqAqIqgKFAAAAAq3RRQAUUUUAf/Z"
阅读原文-演示/下载源码,还有更多更好玩的开源代码等你哦!