使用qrcode.js生成二维码,jsQR识别二维码,结合两者可在前端实现二维码的生成与识别,提升用户体验。通过引入库文件,操作DOM或canvas完成生成与解码,支持动态更新内容及从图片、摄像头实时扫描,需注意环境安全与图像处理细节。

前端实现二维码的生成与识别,能提升用户体验,减少对后端的依赖。通过 JavaScript 可以轻松完成这两项功能,无需跳转或上传图片,直接在浏览器中完成操作。
qrcode.js 是一个轻量级的库,用于将文本内容转换为二维码图像。
使用步骤:
<div id="qrcode"></div>
<script src="https://cdn.jsdelivr.net/npm/qrcode.js/lib/qrcode.min.js"></script>
<script>
new QRCode(document.getElementById("qrcode"), {
text: "https://example.com",
width: 128,
height: 128
});
</script>你也可以动态更新二维码内容,比如用户输入一段文字实时生成。
立即学习“Java免费学习笔记(深入)”;
jsQR 是一个纯 JavaScript 的二维码扫描库,可在 canvas 上解析图像中的二维码。
实现逻辑:
<input type="file" id="qr-input" accept="image/*">
<canvas id="canvas" style="display:none;"></canvas>
<script src="https://cdn.jsdelivr.net/npm/jsqr@1.4.0/dist/jsQR.min.js"></script>
<script>
document.getElementById("qr-input").addEventListener("change", function(e) {
const file = e.target.files[0];
const img = new Image();
img.onload = function() {
const canvas = document.getElementById("canvas");
const ctx = canvas.getContext("2d");
canvas.width = img.width;
canvas.height = img.height;
ctx.drawImage(img, 0, 0);
const data = ctx.getImageData(0, 0, canvas.width, canvas.height);
const code = jsQR(data.data, data.width, data.height);
if (code) {
alert("识别结果:" + code.data);
} else {
alert("未识别到二维码");
}
};
img.src = URL.createObjectURL(file);
});
</script>通过调用 getUserMedia 获取摄像头视频流,配合 jsQR 实现实时扫码功能。
<video id="video" autoplay playsinline></video>
<script>
const video = document.getElementById("video");
navigator.mediaDevices.getUserMedia({ video: { facingMode: "environment" } })
.then(stream => {
video.srcObject = stream;
setTimeout(scan, 500); // 延迟启动识别
});
function scan() {
const canvas = document.createElement("canvas");
const ctx = canvas.getContext("2d");
canvas.width = video.videoWidth;
canvas.height = video.videoHeight;
ctx.drawImage(video, 0, 0);
const data = ctx.getImageData(0, 0, canvas.width, canvas.height);
const code = jsQR(data.data, data.width, data.height);
if (code) {
alert("扫码结果:" + code.data);
} else {
setTimeout(scan, 500); // 继续下一帧
}
}
</script>注意:摄像头功能需在 HTTPS 或本地环境下运行,且用户授权。
基本上就这些。生成用 qrcode.js,识别用 jsQR,两者结合即可实现完整的前端二维码处理能力。不复杂但容易忽略细节,比如 canvas 尺寸、跨域图像、异步加载等。合理封装后可复用性强。
以上就是JS实现前端二维码生成与识别_javascript技巧的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号