当前位置:首页 > 软件开放 > 正文内容

在网站上获取代码(网站上的代码可以复制下来吗)

软件开放1年前 (2023-11-24)524

译者 | 赵青窕

审校 | 孙淑娟

创建二维码生成器(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),从而可以访问http://localhost:3000,以浏览器的形式预览应用。

展开全文

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= "https://hackernoon.com"

/

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= "https://hackernoon.com"

/

button type= "submit"disabled={!url}

Download QR code

/button

/form

/div

/div

);

};

exportdefault QrCode;

上述代码对应的应用程序如下图所示:

本教程描述了创建二维码生成器的过程,以及如何下载以供后续使用。

参考资料:

二维码:

https://github.com/zpao/qrcode.react?ref=hackernoon.com

锚元素(The anchor element):

https://developer.mozilla.org/en-US/docs/Web/HTML/Element/a?ref=hackernoon.com

二维码简介:

https://en.wikipedia.org/wiki/QR_code?ref=hackernoon.com

https://hackernoon.com/how-to-build-a-qr-code-generator-in-react

赵青窕,51CTO社区编辑,从事多年驱动开发。

三连给小编加鸡腿!

扫描二维码推送至手机访问。

版权声明:本文由飞速云SEO网络优化推广发布,如需转载请注明出处。

本文链接:http://zspsrg.cn/post/65559.html

分享给朋友:

“在网站上获取代码(网站上的代码可以复制下来吗)” 的相关文章

苹果手机软件开发(苹果手机软件开发教程)

苹果手机软件开发(苹果手机软件开发教程)

今天给各位分享苹果手机软件开发的知识,其中也会对苹果手机软件开发教程进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、开发苹果app需掌握什么开发工具? 2、在苹果手机开发一款app软件大概需要多少钱 3、ios端的手机app开发要怎么做? 4、开...

学软件开发多少钱(学软件开发多少钱?)

学软件开发多少钱(学软件开发多少钱?)

今天给各位分享学软件开发多少钱的知识,其中也会对学软件开发多少钱?进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、社交软件开发需要多少钱? 2、软件开发培训的费用要多少 3、学软件开发工资高吗? 4、现在的IT培训大概的费用一般都是多少钱?...

手机直播软件开发(手机直播软件开发价格)

手机直播软件开发(手机直播软件开发价格)

今天给各位分享手机直播软件开发的知识,其中也会对手机直播软件开发价格进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、直播App软件开发功能模块有哪些? 2、直播App软件开发功能模块有哪些? 3、想做直播软件开发,如何进行直播平台搭建啊? 直播Ap...

油猴屏蔽网页广告脚本(浏览器去广告脚本)

油猴屏蔽网页广告脚本(浏览器去广告脚本)

今天给各位分享油猴屏蔽网页广告脚本的知识,其中也会对浏览器去广告脚本进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、油猴上脚本已启动,点开学习通视频却没自动跳过怎么回事 2、如何删除网页中残余的油猴脚本? 3、安卓adguard用不了油猴脚本 4...

安利邀请码怎么获取(安利云购邀请码怎么领取)

安利邀请码怎么获取(安利云购邀请码怎么领取)

今天给各位分享安利邀请码怎么获取的知识,其中也会对安利云购邀请码怎么领取进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、安利售后专员邀请码怎么填 2、邀请码如何获取啊???? 3、如何获得论坛邀请码 4、如何获取邀请码。 5、邀请码是怎么弄的...

微信商家小程序怎么申请视频(怎么样申请微信小程序商家)

微信商家小程序怎么申请视频(怎么样申请微信小程序商家)

今天给各位分享微信商家小程序怎么申请视频的知识,其中也会对怎么样申请微信小程序商家进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、微信小程序怎么申请注册? 2、小程序直播怎么申请开通? 3、微信小程序如何申请 微信小程序申请方法 4、怎样注册微信...