密码重置功能:前端
来源:dev.to
2024-10-06 15:03:59
0浏览
收藏
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个Golang开发实战,手把手教大家学习《密码重置功能:前端》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!
前端
与后端部分相比,前端部分非常简单。我需要做的就是创建一个模式,并使用它发送数据两次。
- 首先发送电子邮件将otp发送至
- 然后发送otp和新密码进行更改
为了创建模式,我从我早期项目 chat-nat 的 messagemodal 组件中复制了一些代码,即用于封装模式的类名。
规划
我会添加“忘记密码?”登录页面上的按钮,并设置 onclick 处理程序以打开模态
在请求之前,我需要使用布尔状态来表示 otp 是否已发送到用户的电子邮件。我将状态命名为 otpsent
- 如果 !isotpsent -> 只是询问电子邮件地址,发送 api 请求,则如果成功 setotpsent(true)
- 如果 isotpsent -> 现在还要求输入 otp 和新密码,那么如果成功,则关闭模式
以下是我从该项目的现有前端重用的一些组件和挂钩:
- box -> 它将我的登录和注册页面整齐地包装到一张卡片中,以页面为中心,在这里重用,标题为“密码重置”
- authform -> 只是一个表单,但我对其进行编码以在我们等待服务器响应时禁用提交按钮并将按钮文本设置为“正在加载...”
- forminput -> 带有自己标签的输入字段,带有值设置器和 onchange 处理程序,可选带有 isrequired 布尔值
- 使用axios -> 自定义挂钩来处理来自需要令牌刷新的服务器的响应。 apireq 函数用于正常请求发送,一些自定义错误处理用于显示alert() 和刷新令牌,refreshreq 函数用于刷新身份验证令牌并再次尝试初始请求。
这是模态的完整代码:
// src/components/passwordresetmodal.tsx import react, { usestate } from "react" import authform from "./authform"; import forminput from "./forminput"; import box from "./box"; import { useaxios } from "../hooks/useaxios"; interface formdata { email: string, new_password: string, otp: string, } interface props { isvisible: boolean, onclose: () => void, } const passwordresetmodal: react.fc<props> = ({ isvisible, onclose }) => { const [formdata, setformdata] = usestate<formdata>({ email: "", new_password: "", otp: "" }); const [isloading, setloading] = usestate<boolean>(false); const [isotpsent, setotpsent] = usestate<boolean>(false); const { apireq } = useaxios(); const handleclose = (e: react.mouseevent<htmldivelement, mouseevent>) => { if ((e.target as htmlelement).id === "wrapper") { onclose(); // could have setotpsent(false), but avoiding it in case user misclicks outside } }; const handlechange = (e: react.changeevent<htmlinputelement>) => { const { name, value } = e.target; setformdata({ ...formdata, [name]: value, }); }; const handlesubmit = async (e: react.formevent<htmlformelement>) => { e.preventdefault(); setloading(true); if (!isotpsent) { // first request for sending otp, const response = await apireq<unknown, formdata>("post", "/api/reset-password", formdata) if (response) { alert("otp has been sent to your email"); setotpsent(true); } } else { // then using otp to change password const response = await apireq<unknown, formdata>("put", "/api/reset-password", formdata) if (response) { alert("password has been successfully reset\nplease log in again"); // clear the form setformdata({ email: "", otp: "", new_password: "", }) // close modal onclose(); } } setloading(false); }; if (!isvisible) return null; return ( <div id="wrapper" classname="fixed inset-0 bg-black bg-opacity-25 backdrop-blur-sm flex justify-center items-center" onclick={handleclose}> <box title="password reset"> <authform submithandler={handlesubmit} isloading={isloading} buttontext={isotpsent ? "change password" : "send otp"}> <forminput id="email" label="your email" type="email" value={formdata.email} changehandler={handlechange} isrequired /> {isotpsent && (<> <forminput id="otp" label="otp" type="text" value={formdata.otp} changehandler={handlechange} isrequired /> <forminput id="new_password" label="new password" type="password" value={formdata.new_password} changehandler={handlechange} isrequired /> </>)} </authform> </box> </div> ) } export default passwordresetmodal
这是在登录表单中处理模式的条件渲染的方式
// src/pages/auth/Login.tsx import PasswordResetModal from "../../components/PasswordResetModal"; const Login: React.FC = () => { const [showModal, setShowModal] = useState<boolean>(false); return ( <Section> <Box title="Login"> <div className="grid grid-flow-col"> {/* link to the register page here */} <button type="button" onClick={() => setShowModal(true)} className="text-blue-700 hover:text-white border border-blue-700 hover:bg-blue-800 focus:ring-4 focus:outline-none focus:ring-blue-300 font-medium rounded-lg text-sm px-3 py-2 text-center me-2 mb-2 dark:border-blue-500 dark:text-blue-500 dark:hover:text-white dark:hover:bg-blue-500 dark:focus:ring-blue-800"> Forgot Password? </button> <PasswordResetModal isVisible={showModal} onClose={() => setShowModal(false)} /> </div> </Box> </Section> )
我们完成了!至少我是这么想的。
在我的开发环境中运行该应用程序时,我发现了一个错误,如果后端已经运行很长时间,则电子邮件将无法通过。
我们将在下一篇文章中修复此错误
今天关于《密码重置功能:前端》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除

- 上一篇
- Java 函数中不可变和可变参数之间的区别?

- 下一篇
- 如何在不支持的硬件上的虚拟机中安装Windows 11
查看更多
最新文章
-
- Golang · Go教程 | 3分钟前 | golang Http请求 数据库操作 超时控制 context.Context
- 手把手教你Golang中context.Context超时控制优化技巧
- 246浏览 收藏
-
- Golang · Go教程 | 26分钟前 |
- Go语言避坑指南:手把手教你解决空指针异常
- 316浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- debian怎么分区加密?手把手教你设置加密分区
- 162浏览 收藏
-
- Golang · Go教程 | 2小时前 | 协程调度 并发性能 GOMAXPROCS GMP模型 任务类型
- Golang协程调度实战:手把手教你玩转P的数量
- 286浏览 收藏
-
- Golang · Go教程 | 2小时前 | golang 排序算法 快速排序 sort包 sort.Interface
- Golang手把手教你实现各种排序算法,超详细教程!
- 102浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
查看更多
AI推荐
-
- 茅茅虫AIGC检测
- 茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
- 85次使用
-
- 赛林匹克平台(Challympics)
- 探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
- 93次使用
-
- 笔格AIPPT
- SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
- 97次使用
-
- 稿定PPT
- 告别PPT制作难题!稿定PPT提供海量模板、AI智能生成、在线协作,助您轻松制作专业演示文稿。职场办公、教育学习、企业服务全覆盖,降本增效,释放创意!
- 91次使用
-
- Suno苏诺中文版
- 探索Suno苏诺中文版,一款颠覆传统音乐创作的AI平台。无需专业技能,轻松创作个性化音乐。智能词曲生成、风格迁移、海量音效,释放您的音乐灵感!
- 91次使用
查看更多
相关文章
-
- Golangmap实践及实现原理解析
- 2022-12-28 505浏览
-
- 试了下Golang实现try catch的方法
- 2022-12-27 502浏览
-
- Go语言中Slice常见陷阱与避免方法详解
- 2023-02-25 501浏览
-
- Golang中for循环遍历避坑指南
- 2023-05-12 501浏览
-
- Go语言中的RPC框架原理与应用
- 2023-06-01 501浏览