如何使用React创建QR code生成器
译者 | 赵青窕
审校 | 孙淑娟
创建二维码生成器(Quick Response Code Generator)就是将图像格式转换为文本格式进行转换。二维码(QR code)是利用图像数据来代表文本信息,它有很多使用场景,如餐厅菜单,音乐会门票,在线日历邀请、支付等场景。
在本教程中,你将学习如何使用Java库React创建二维码。React为开发人员提供了重用组件的方式,使得构建前端使用程序变得轻而易举。
前提条件
要足够理解本文,你需要具备以下知识和环境:
了解React.js基本内容
你的环境需要称心Node = 14.0.0,npm = 5.6
了解React.js基本内容
你的环境需要称心Node = 14.0.0,npm = 5.6
预备工作
首先,打开终端并运行以下命令:
npx create-react-app qrcode-generator
上面的命令附带了必要的文件,并安装了创建React使用程序所需的软件包。
接下来,使用下面的命令切换到自己构建的项目目录下,并运行开发服务器(Development Server),从而可以访问,以浏览器的形式预览使用。
展开全文
cdqrcode-generator
npm start
最后,让我们使用下面的命令安装创建二维码生成器所需的依靠库:
npm install qrcode.react
qrcode.react:一个React组件,用于生成二维码,并将其显现给DOM。
创建二维码生成器
二维码生成器的创建将从创建包含二维码结构的文件和组件开始。在src目录中,创建一个名为components的文件夹,并在文件夹中创建一个名为QrCode.js的文件。下面是对应的代码实现方式:
// src/components/QrCode.js
import { useState } from "react";
import { QRCodeCanvas } from "qrcode.react";
const QrCode = = {
const [url, setUrl] = useState( "");
const downloadQRCode = (e) = {
e.preventDefault;
setUrl( "");
const qrCodeEncoder = (e) = {
setUrl(e.target.value);
const qrcode = (
QRCodeCanvas
id= "qrCode"
value={url}
size={300}
bgColor={ "#00ff00"}
level={ "H"}
return(
div className= "qrcode__container"
div{qrcode}/div
div className= "input__group"
form onSubmit={downloadQRCode}
labelEnter URL/label
input
type= "text"
value={url}
onChange={qrCodeEncoder}
placeholder= ""
button type= "submit"disabled={!url}
Download QR code
/button
/form
/div
/div
exportdefault QrCode;
左右滑动查看完全代码
上面的代码片段做了如下操作:
Import useState用于声明变量的初始状态,url设置为空字符串, setState函数和setUrl用于更新状态;
库qrcode.react用于显现生成的二维码;
接下来,使用from element中,附加到onSubmit方法中的downloadQRCode函数,该过程由submit事件触发;
在input元素中,带有函数' qrCodeEncoder '的onChange事件处理程序用来接收用户的输进,并依据获取的输进值更改二维码;
创建一个变量qrcode。它接受QRCodeCanvas组件,并传递一些可用的自定义属性,使二维码可以在浏览器上展示出来。
最后,button元素将被禁用,直到接收到用户输进数据。
Import useState用于声明变量的初始状态,url设置为空字符串, setState函数和setUrl用于更新状态;
库qrcode.react用于显现生成的二维码;
接下来,使用from element中,附加到onSubmit方法中的downloadQRCode函数,该过程由submit事件触发;
在input元素中,带有函数' qrCodeEncoder '的onChange事件处理程序用来接收用户的输进,并依据获取的输进值更改二维码;
创建一个变量qrcode。它接受QRCodeCanvas组件,并传递一些可用的自定义属性,使二维码可以在浏览器上展示出来。
最后,button元素将被禁用,直到接收到用户输进数据。
设计二维码使用程序
在src文件夹中,创建样式表(stylessheet)styles.css,该部分负责使用程序的展示效果, 下面是对应的代码实现方式:
/* src/styles.css */
*:before,
*:after {
margin: 0;
padding: 0;
box-sizing: border-box;
:root {
--font-color: 230 35% 7%;
body {
color: hsl(var(--font-color));
img {
max-width: 100%;
display: block;
.section {
padding: 2em 0;
display: flex;
min-height: 100vh;
align-items: center;
.container {
margin-inline: auto;
max-width: 75rem;
width: 85%;
.input__group {
display: flex;
margin-top: 2em;
input {
width: 100%;
padding: 1em 0.75em;
border: 1px solid #444343;
border-radius: 3px;
margin-bottom: 2em;
margin-top: 0.75em;
button {
border: unset;
background: hsl(231, 77%, 90%);
padding: 1em 0.75em;
color: hsl(var(--font-color));
cursor: pointer;
text-transform: uppercase;
font-weight: bold;
@media screen and (min-width: 768px) {
.section {
padding: 0;
input {
margin: 0;
.qrcode__container {
display: flex;
align-items: center;
.input__group {
margin-left: 3em;
input {
margin-bottom: 2em;
margin-top: 0.75em;
font-size: 1rem;
左右滑动查看完全代码
接下来,在app的进口app .js中导进QrCode.js文件和样式表:
// src/App.js
import QrCode from "./components/QrCode";
import "./styles.css";
exportdefault functionApp{
return(
div className= "section container"
QrCode /
/div
左右滑动查看完全代码
完成上面步骤后,app展示如下图所示:
用户可以抉择下载生成的二维码,使得它可以使用在各种各样的用例中。从打二维码的打印到将其嵌进网站,这样的例子不胜枚举。
回到components/QrCode.js文件,让我们更新代码库,以使用refs来访问文档对象模型节点(DOM Node)。
// src/components/QrCode.js
import { useState, useRef } from "react";
// other import
const QrCode = = {
const [url, setUrl] = useState( "");
const qrRef = useRef; // include this: call the useRef function
const qrcode = (
QRCodeCanvas
id= "qrCode"
value={url}
size={300}
bgColor={ "#00ff00"}
level={ "H"}
return(
div className= "qrcode__container"
div ref={qrRef}{qrcode}/div {/* include this */}
{/* form input container */}
/div
exportdefault QrCode;
左右滑动查看完全代码
现在,让我们更新QrCode.js文件中的downloadQRCode函数,以便能够单击下载二维码按钮并将下载后的文件保存为图像文件。
// src/components/QrCode.js
// imports
const QrCode = = {
// state
// useRef
const downloadQRCode = (e) = {
e.preventDefault;
letcanvas = qrRef.current.querySelector( "canvas");
letimage = canvas.toDataURL( "image/png");
letanchor = document.( "a");
anchor.href = image;
anchor.download = `qr-code.png`;
document.body.(anchor);
anchor.click;
document.body.removeChild(anchor);
setUrl( "");
return(
div className= "qrcode__container"
div ref={qrRef}{qrcode}/div
{/* form input container */}
/div
exportdefault QrCode;
左右滑动查看完全代码
在downloadQRCode函数中,主要完成了以下任务:
它使用ref对象的.current属性来获取当前值,以便知道节点何时发生转变;
利用qrcode.react组件在DOM中生成canvas元素,可以动态创建内容;
canvas被追加到toDataURL方法中,且指定器类型为文件格式image/png;
接下来,创建锚元素(Anchor Element),并将href设置为单击按钮时下载二维码的图像;
anchor被附加到文档主体,一旦二维码下载后,它就会被删除;
最后,使用setUrl变量更新状态url,该操作在执行submit后会清除二维码对应的输进。
它使用ref对象的.current属性来获取当前值,以便知道节点何时发生转变;
利用qrcode.react组件在DOM中生成canvas元素,可以动态创建内容;
canvas被追加到toDataURL方法中,且指定器类型为文件格式image/png;
接下来,创建锚元素(Anchor Element),并将href设置为单击按钮时下载二维码的图像;
anchor被附加到文档主体,一旦二维码下载后,它就会被删除;
最后,使用setUrl变量更新状态url,该操作在执行submit后会清除二维码对应的输进。
最后的完全代码如下:
import { useState, useRef } from "react";
import { QRCodeCanvas } from "qrcode.react";
const QrCode = = {
const [url, setUrl] = useState( "");
const qrRef = useRef;
const downloadQRCode = (e) = {
e.preventDefault;
letcanvas = qrRef.current.querySelector( "canvas");
letimage = canvas.toDataURL( "image/png");
letanchor = document.( "a");
anchor.href = image;
anchor.download = `qr-code.png`;
document.body.(anchor);
anchor.click;
document.body.removeChild(anchor);
setUrl( "");
const qrCodeEncoder = (e) = {
setUrl(e.target.value);
const qrcode = (
QRCodeCanvas
id= "qrCode"
value={url}
size={300}
bgColor={ "#00ff00"}
level={ "H"}
return(
div className= "qrcode__container"
div ref={qrRef}{qrcode}/div
div className= "input__group"
form onSubmit={downloadQRCode}
labelEnter URL/label
input
type= "text"
value={url}
onChange={qrCodeEncoder}
placeholder= ""
button type= "submit"disabled={!url}
Download QR code
/button
/form
/div
/div
exportdefault QrCode;
上述代码对应的使用程序如下图所示:
本教程描述了创建二维码生成器的过程,以及如何下载以供后续使用。
参考资料:
二维码:
锚元素(The anchor element):
二维码简介:
赵青窕,51CTO社区编辑,从事多年驱动开发。
三连给小编加鸡腿!