前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >基于HTML5 canvas的纯JS二维码生成

基于HTML5 canvas的纯JS二维码生成

作者头像
用户5997198
发布2019-09-08 12:10:09
1.8K0
发布2019-09-08 12:10:09
举报
文章被收录于专栏:蚂蚁开源社区蚂蚁开源社区

简要教程

qrious是一款基于HTML5 canvas的纯JS二维码生成插件。通过qrious.js可以快速生成各种二维码,你可以控制二维码的尺寸颜色,还可以将生成的二维码进行Base64编码。

安装

可以通过bower或npm来安装qrious.js二维码插件。

代码语言:javascript
复制
$ npm install --save qrious$ bower install --save qrious

使用方法

使用该二维码生成插件需要在页面中引入qrious.js文件。

代码语言:javascript
复制
<script type="text/javascript" src="js/qrious.js"></script>

HTML结构

使用一个<canvas>元素来作为二维码图片的容器。

代码语言:javascript
复制
<canvas id="qr"></canvas>

初始化插件

可以通过QRious()方法来实例化一个对象实例。

代码语言:javascript
复制
(function() {const qr = new QRious({element: document.getElementById('qr'),value: 'http://www.htmleaf.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.htmleaf.com/' })res.end(new Buffer(qr.toDataURL(), 'base64'))})app.listen(3000)

配置参数

qrious.js二维码插件的可用配置参数如下:

参数 类型 默认值 描述

background String "white" 二维码的背景颜色。

foreground String "black" 二维码的前景颜色。

level String "L" 二维码的误差校正级别(L, M, Q, H)。

mime String "image/png" 二维码输出为图片时的MIME类型。

size Number 100 二维码的尺寸,单位像素。

value String "" 需要编码为二维码的值

例如:

代码语言:javascript
复制
const qr = new QRious()qr.background = '#000'qr.foreground = '#fff'qr.level = 'H'qr.size = 500qr.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"

作者 | 蚂蚁大喇叭 | 蚂蚁开源社区大神,资深开发工程师

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-09-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 蚂蚁大喇叭 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档