uniapp 生成二维码

一般常用到的二维码生成库,在使用的过程中,都需要设置到指定的dom元素上,

但是在 uniapp 项目中,想要像vue项目中一样,获取标签的dom元素是比较难操作的。所以在 uniapp 中生成二维码,就需要换一种思路,通过 canvas 画布,将二维码进行绘制并放置在 canvas 中进行展示。

uQRCode是一款基于Javascript环境开发的二维码生成插件,适用所有Javascript运行环境的前端应用和Node.js应用。 uQRCode可扩展性高,它支持自定义渲染二维码,可通过uQRCode API得到二维码绘制关键信息后,使用canvas、svg或js操作dom的方式绘制二维码图案。还可自定义二维码样式,如随机颜色、圆点、方块、块与块之间的间距等。

插件地址:uQRCode 全端二维码生成插件 支持nvue 支持nodejs服务端 - DCloud 插件市场

git地址:https://github.com/Sansnn/uQRCode

1. 安装
1.1 通过npm安装,成功后即可使用import或require进行引用。
javascript 复制代码
# npm安装
npm install uqrcodejs
# 或者
npm install @uqrcode/js
1.2 通过项目开源地址获取uqrcode.js,下载uqrcode.js后,将其复制到您项目指定目录,在页面中引入uqrcode.js文件即可开始使用。
2. 引入

通过import引入。

javascript 复制代码
// npm安装
import UQRCode from 'uqrcodejs'; // npm install uqrcodejs
// 或者
import UQRCode from '@uqrcode/js'; // npm install @uqrcode/js

Node.js通过require引入。

javascript 复制代码
// npm安装
const UQRCode = require('uqrcodejs'); // npm install uqrcodejs
// 或者
const UQRCode = require('@uqrcode/js'); // npm install @uqrcode/js
3. 使用
html 复制代码
<canvas id="qrcode" canvas-id="qrcode" style="width: 200px;height: 200px;"></canvas>
javascript 复制代码
nextTick(() => {
			// 获取uQRCode实例
			const qr = new UQRCode();
			// 设置二维码内容
			qr.data = "https://uqrcode.cn/doc";
			// 设置二维码大小,必须与canvas设置的宽高一致
			qr.size = 200;
			// 调用制作二维码方法
			qr.make();
			// 获取canvas上下文
			const canvasContext = uni.createCanvasContext('qrcode', this); // 如果是组件,this必须传入
			// 设置uQRCode实例的canvas上下文
			qr.canvasContext = canvasContext;
			// 调用绘制方法将二维码图案绘制到canvas上
			qr.drawCanvas();
		})

二维码成功生成!

相关推荐
BillKu29 分钟前
Vue3 + Element-Plus 抽屉关闭按钮居中
前端·javascript·vue.js
DevilSeagull32 分钟前
JavaScript WebAPI 指南
java·开发语言·javascript·html·ecmascript·html5
大怪v2 小时前
前端佬:机器学习?我也会啊!😎😎😎手“摸”手教你做个”自动驾驶“~
前端·javascript·机器学习
源码师傅2 小时前
uniapp开源多商户小程序商城平台源码 支持二次开发+永久免费升级
小程序·uni-app·多商户商城源码·uniapp开源商城源码·开源多商户小程序商城平台·商城小程序代码·多商户商城小程序源码
梦远青城4 小时前
C#地方门户网站 基于NET6.0、Admin.NET,uniapp,vue3,elementplus开源的地方门户网站项目
uni-app·开源·门户网站·地方生活网站·本地租房·本地找工作·东川本地生活
gnip4 小时前
链式调用和延迟执行
前端·javascript
杨天天.4 小时前
小程序原生实现音频播放器,下一首上一首切换,拖动进度条等功能
前端·javascript·小程序·音视频
Dragon Wu5 小时前
React state在setInterval里未获取最新值的问题
前端·javascript·react.js·前端框架
YU大宗师5 小时前
React面试题
前端·javascript·react.js
给月亮点灯|6 小时前
Vue基础知识-Vue集成 Element UI全量引入与按需引入
前端·javascript·vue.js