更新记录
4.0.6(2022-12-12) 下载此版本
修复getDrawModules
,第一次获取结果正常,后续获取tile
模块不存在的问题;
修复安卓type:normal因Canvas API使用了小数或为0的参数导致生成异常的问题(注:安卓非2d Canvas部分API参数不支持携带小数,部分API参数必须大于0)。
4.0.1(2022-11-28) 下载此版本
优化组件loading属性的表现;
新增组件type选项normal,以便于在某些条件编译初始为type=2d时还可以选择使用非2d组件类型;
修复组件条件编译在其他编辑器语法提示报错;
修复原生对es5的支持。
4.0.0(2022-11-21) 下载此版本
v4版本源代码全面开放,开源地址:https://github.com/Sansnn/uQRCode;
升级说明:v4为大版本更新,虽然已尽可能兼容上一代版本,但不可避免的还是存在一些细节差异,若更新后出现问题,请参考对照v3 文档,v4 文档进行修改。
查看更多平台兼容性
Vue2 | Vue3 |
---|---|
√ | √ |
App | 快应用 | 微信小程序 | 支付宝小程序 | 百度小程序 | 字节小程序 | QQ小程序 |
---|---|---|---|---|---|---|
app-vue app-nvue | √ | √ | √ | √ | √ | √ |
钉钉小程序 | 快手小程序 | 飞书小程序 | 京东小程序 |
---|---|---|---|
× | × | × | × |
H5-Safari | Android Browser | 微信浏览器(Android) | QQ浏览器(Android) | Chrome | IE | Edge | Firefox | PC-Safari |
---|---|---|---|---|---|---|---|---|
√ | √ | √ | √ | √ | √ | √ | √ | √ |
介绍
uQRCode
是一款基于Javascript
环境开发的二维码生成插件,适用所有Javascript
运行环境的前端应用和Node.js
应用。
uQRCode
可扩展性高,它支持自定义渲染二维码,可通过uQRCode API
得到二维码绘制关键信息后,使用canvas
、svg
或js
操作dom
的方式绘制二维码图案。还可自定义二维码样式,如随机颜色、圆点、方块、块与块之间的间距等。
欢迎加入群聊【uQRCode交流群】:695070434。
微信小程序搜索“柚子二维码”,或扫描下方小程序码体验。
示例
快速上手
在
uni-app
中,我们更推荐使用组件方式来生成二维码,组件方式大大提高了页面的可读性以及避开了一些平台容易出问题的地方,当组件无法满足需求的时候,再考虑切换成原生方式。
官方文档:https://uqrcode.cn/doc。
github地址:https://github.com/Sansnn/uQRCode。
npm地址:https://www.npmjs.com/package/uqrcodejs。
uni-app插件市场地址:https://ext.dcloud.net.cn/plugin?id=1287。
原生方式
原生方式仅需要获取uqrcode.js
文件便可使用。详细配置请移步到:文档 > 原生。
安装
-
通过
npm
安装,成功后即可使用import
或require
进行引用。# npm安装 npm install uqrcodejs # 或者 npm install @uqrcode/js
-
通过项目开源地址获取
uqrcode.js
,下载uqrcode.js
后,将其复制到您项目指定目录,在页面中引入uqrcode.js
文件即可开始使用。
引入
-
通过
import
引入。// npm安装 import UQRCode from 'uqrcodejs'; // npm install uqrcodejs // 或者 import UQRCode from '@uqrcode/js'; // npm install @uqrcode/js
-
Node.js
通过require
引入。// npm安装 const UQRCode = require('uqrcodejs'); // npm install uqrcodejs // 或者 const UQRCode = require('@uqrcode/js'); // npm install @uqrcode/js
-
原生浏览器环境,在js脚本加载时添加到
window
。<script type="text/javascript" src="uqrcode.js"></script> <script> var UQRCode = window.UQRCode; </script>
简单用法
uQRCode
基于Canvas API
封装了一套方法,建议开发者使用canvas
生成,一键调用,非常方便。以下是示例:
-
HTML示例
-
DOM部分
<canvas id="qrcode" width="200" height="200"></canvas>
-
JS部分
// 获取uQRCode实例 var qr = new UQRCode(); // 设置二维码内容 qr.data = "https://uqrcode.cn/doc"; // 设置二维码大小,必须与canvas设置的宽高一致 qr.size = 200; // 调用制作二维码方法 qr.make(); // 获取canvas元素 var canvas = document.getElementById("qrcode"); // 获取canvas上下文 var canvasContext = canvas.getContext("2d"); // 设置uQRCode实例的canvas上下文 qr.canvasContext = canvasContext; // 调用绘制方法将二维码图案绘制到canvas上 qr.drawCanvas();
-
-
uni-app示例
-
Template部分
<canvas id="qrcode" canvas-id="qrcode" style="width: 200px;height: 200px;"></canvas>
-
JS部分
onReady() { // 获取uQRCode实例 var qr = new UQRCode(); // 设置二维码内容 qr.data = "https://uqrcode.cn/doc"; // 设置二维码大小,必须与canvas设置的宽高一致 qr.size = 200; // 调用制作二维码方法 qr.make(); // 获取canvas上下文 var canvasContext = uni.createCanvasContext('qrcode', this); // 如果是组件,this必须传入 // 设置uQRCode实例的canvas上下文 qr.canvasContext = canvasContext; // 调用绘制方法将二维码图案绘制到canvas上 qr.drawCanvas(); }
-
-
微信小程序,推荐使用Canvas 2D,关于Canvas 2D的使用请参考微信开放文档。
高级用法
考虑到部分平台可能不支持canvas
,所以uQRCode
并没有强制要求和canvas
一起使用,您还可以选择其他方式来生成二维码,例如使用js
操作dom
进行绘制或是使用svg
绘制等。以下是示例:
- uni-app v-for+view
<template>
<view>
<view class="qrcode">
<view v-for="(row, rowI) in modules" :key="rowI" style="display: flex;flex-direction: row;">
<view v-for="(col, colI) in row" :key="colI">
<view v-if="col.isBlack" style="width: 10px;height: 10px;background-color: black;">
<!-- 黑色码点 -->
</view>
<view v-else style="width: 10px;height: 10px;background-color: white;">
<!-- 白色码点 -->
</view>
</view>
</view>
</view>
</view>
</template>
<script>
import UQRCode from '../../uni_modules/Sansnn-uQRCode/js_sdk/uqrcode/uqrcode.js';
export default {
data() {
return {
modules: []
}
},
onLoad() {
const qr = new UQRCode();
qr.data = 'uQRCode';
qr.make();
this.modules = qr.modules;
},
methods: {
}
}
</script>
- js操作dom
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>uQRCode二维码生成</title>
</head>
<body>
<div id="qrcode" style="position: relative;"></div>
<script type="text/javascript" src="uqrcode.js"></script>
<script>
// 引入uQRCode
var UQRCode = window.UQRCode;
// 获取uQRCode实例
var qr = new UQRCode();
// 设置二维码内容
qr.data = "https://uqrcode.cn/doc";
// 设置二维码大小,必须与canvas设置的宽高一致
qr.size = 200;
// 设置二维码前景图,可以是路径
qr.foregroundImageSrc =
'';
// 调用制作二维码方法
qr.make();
var drawModules = qr.getDrawModules();
// 遍历drawModules创建dom元素
var qrHtml = '';
for (var i = 0; i < drawModules.length; i++) {
var drawModule = drawModules[i];
switch (drawModule.type) {
case 'tile':
/* 绘制小块 */
qrHtml += `<div style="position: absolute;left: ${drawModule.x}px;top: ${drawModule.y}px;width: ${drawModule.width}px;height: ${drawModule.height}px;background: ${drawModule.color};"></div>`;
break;
case 'image':
/* 绘制图像 */
qrHtml += `<img style="position: absolute;left: ${drawModule.x}px;top: ${drawModule.y}px;width: ${drawModule.width}px;height: ${drawModule.height}px;" src="${drawModule.imageSrc}" />`;
break;
}
}
document.getElementById('qrcode') = qrHtml;
</script>
</body>
</html>
-
svg
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>uQRCode二维码生成</title> </head> <body> <svg id="qrcode" width="200" height="200" xmlns="http://www.w3.org/2000/svg" version="1.1"></svg> <script type="text/javascript" src="uqrcode.js"></script> <script> // 引入uQRCode var UQRCode = window.UQRCode; // 获取uQRCode实例 var qr = new UQRCode(); // 设置二维码内容 qr.data = "https://uqrcode.cn/doc"; // 设置二维码大小,必须与canvas设置的宽高一致 qr.size = 200; // 设置二维码前景图,可以是路径 qr.foregroundImageSrc = ''; // 调用制作二维码方法 qr.make(); var drawModules = qr.getDrawModules(); // 遍历drawModules创建svg元素 var qrHtml = ''; for (var i = 0; i < drawModules.length; i++) { var drawModule = drawModules[i]; switch (drawModule.type) { case 'tile': /* 绘制小块 */ qrHtml += `<rect x="${drawModule.x}" y="${drawModule.y}" width="${drawModule.width}" height="${drawModule.height}" style="fill: ${drawModule.color};" />`; break; case 'image': /* 绘制图像 */ qrHtml += `<image href="${drawModule.imageSrc}" x="${drawModule.x}" y="${drawModule.y}" width="${drawModule.width}" height="${drawModule.height}" />`; break; } } document.getElementById('qrcode') = qrHtml; </script> </body> </html>
更多用法大家自行探索咯,期待分享哟~
导出临时文件路径
原生方式基于Canvas
的,请自行参阅各平台Canvas
的导出方式。以下是部分示例:
-
uni-app
// 通过uni.createCanvasContext方式创建绘制上下文的,对应导出API为uni.canvasToTempFilePath // 调用完ctx.draw()方法后不能第一时间导出,否则会异常,需要有一定的延时 setTimeout(() => { uni.canvasToTempFilePath( { canvasId: this.canvasId, fileType: this.fileType, width: this.canvasWidth, height: this.canvasHeight, success: res => { console.log(res); }, fail: err => { console.log(err); } }, // this // 组件内使用必传当前实例 ); }, 300);
-
Canvas2D
// 得到base64 console.log(canvas.toDataURL()); // 得到buffer console.log(canvas.toBuffer());
保存二维码到本地相册
必须在导出临时文件路径成功后再执行保存。uni-app通用保存方式(H5除外):
uni.saveImageToPhotosAlbum({
filePath: tempFilePath,
success: res => {
console.log(res);
},
fail: err => {
console.log(err);
}
});
H5可以通过设置<a>
标签href
属性的方式进行保存:
const aEle = document.createElement('a');
aEle.download = 'uQRCode'; // 设置下载的文件名,默认是'下载'
aEle.href = tempFilePath;
document.body(aEle);
aEle.click();
aEle.remove(); // 下载之后把创建的元素删除
经过测试,PC端浏览器可以下载,部分安卓自带或第三方浏览器可以下载,安卓微信浏览器不适用,移动端iOS所有浏览器均不适用,差异较大,还是推荐各位导出文件给图片组件显示,然后提示用户通过长按图片进行保存这种方式。
uni-app组件方式
安装
通过uni-app插件市场地址安装:https://ext.dcloud.net.cn/plugin?id=1287。详细配置请移步到:文档 > uni-app组件。
引入
uni-app默认为easycom模式,可直接键入<uqrcode>
标签。
简单用法
安装uqrcode
组件后,在template
中键入<uqrcode/>
。设置ref
属性可使用组件内部方法,canvas-id
属性为组件内部的canvas组件标识,value
属性为二维码生成对应内容,options
为配置选项,可配置二维码样式,绘制Logo等,详见:options 。
<uqrcode ref="uqrcode" canvas-id="qrcode" value="https://uqrcode.cn/doc" :options="{ margin: 10 }"></uqrcode>
导出临时文件路径
为了保证方法调用成功,请在 complete 事件返回success=true
后调用。
// uqrcode为组件的ref名称
this.$refs.uqrcode.toTempFilePath({
success: res => {
console.log(res);
}
});
保存二维码到本地相册
为了保证方法调用成功,请在 complete 事件返回success=true
后调用。
// uqrcode为组件的ref名称
this.$refs.uqrcode.save({
success: () => {
uni.showToast({
icon: 'success',
title: '保存成功'
});
}
});