手机号验证码重新发送

前文叙述

很久以前做的一个 demo ,纯 HTML 、CSS、js 制作,一定时间段之后才可以重新发送验证码,如 60s
后再次发送验证码,在该时间段内发送验证码按钮为禁用状态,实战开发过程也亦是同理,因此记录一手。

一、效果图:

请添加图片描述

二、实现代码:

<!DOCTYPE html>
<html>
<head><title>登录表单</title><style>body {font-family: Arial, sans-serif;background-color: #f2f2f2;min-height: 100vh;display: flex;justify-content: center;align-items: center;border-}.container {max-width: 400px;min-width: 400px;margin: auto;padding: 20px;background-color: #fff;border-radius: 5px;box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);}h2 {text-align: center;margin-bottom: 30px;}.form-group {margin-bottom: 20px;}.form-group-inline {display: flex;align-items: center;}label {display: block;font-weight: bold;margin-bottom: 5px;flex: 0 0 100px;}input[type="text"],input[type="password"] {flex: 1;padding: 10px;border: 1px solid #ddd;border-radius: 4px;box-sizing: border-box;}input[type="text"]:fous{border-color: #ebecff;}.btn {display: inline-block;padding: 10px 20px;background-color: #4caf50;color: #fff;text-align: center;text-decoration: none;border-radius: 4px;cursor: pointer;transition: background-color 0.3s;}#code {width: 100px;margin-right: 30px;}.btn:hover {background-color: #45a049;}.btn-disabled {background-color: #ccc;cursor: not-allowed;}</style>
</head>
<body><div class="container"><h2>登录</h2><div class="form-group form-group-inline"><label for="phone">手机号码:</label><input type="text" id="phone" placeholder="请输入手机号码"></div><div class="form-group form-group-inline"><label for="code">验证码:</label><input type="text" id="code" placeholder="请输入验证码"><button id="sendCode" class="btn">发送验证码</button></div><button id="loginBtn" class="btn">登录</button></div><script>// 获取DOM元素const phoneInput = document.getElementById('phone');const codeInput = document.getElementById('code');const sendCodeBtn = document.getElementById('sendCode');const loginBtn = document.getElementById('loginBtn');let timer;let countdown = 60;function validatePhoneNumber(phoneNumber) {// 使用正则表达式进行手机号码校验let regex = /^1[0-9]{10}$/;return regex.test(phoneNumber);}function validateVerificationCode(code) {// 使用正则表达式进行六位数验证码校验let regex = /^\d{6}$/;return regex.test(code);
}// 发送验证码按钮点击事件sendCodeBtn.addEventListener('click', () => {if (!phoneInput.value) {alert('请输入手机号码');return;}if (!this.validatePhoneNumber(phoneInput.value)) {alert("请输入合法手机号");return;}// 禁用发送验证码按钮sendCodeBtn.disabled = true;sendCodeBtn.classList.add('btn-disabled');// 开始倒计时countdown = 10;sendCodeBtn.innerText = `${countdown}s`;sendCodeBtn.style.display = 'block';timer = setInterval(() => {countdown--;if (countdown === 0) {// 倒计时结束,恢复发送验证码按钮状态clearInterval(timer);sendCodeBtn.disabled = false;sendCodeBtn.classList.remove('btn-disabled');sendCodeBtn.innerText = "发送验证码";} else {sendCodeBtn.innerText = `${countdown}s`;}}, 1000);// 模拟发送验证码的逻辑,这里使用了setTimeoutsetTimeout(() => {alert('验证码已发送,请注意查收');}, 2000);});// 登录按钮点击事件loginBtn.addEventListener('click', () => {// 检查手机号和验证码是否为空if (!phoneInput.value || !this.validatePhoneNumber(phoneInput.value)) {alert('请输入合法手机号');return;}if (!this.validateVerificationCode(codeInput.value)) {alert('请输入合法验证码');return;}});</script>
</body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/733031.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

内存的基本特性

初识内存 1&#xff0c;内存的基本特性 现代计算机的基本组成 现代计算机之父--冯诺伊曼提出了计算机的基本组成&#xff1a; 运算器&#xff1a;负责算术运算和逻辑运算&#xff0c;目前已经集成到CPU中。 控制器&#xff1a;负责控制系统的各部件&#xff0c;使之协调的…

【笔记】Android ServiceStateTracker 网络状态变化逻辑及SPN更新影响

业务简介 在网络状态变化的时候&#xff08;数据或WiFi&#xff09;&#xff0c;会更新SPN。 基于Android U的代码分析。 分类&#xff1a;SPN Data_Dic-的博客-CSDN博客 功能逻辑 状态说明 飞行模式下注册上WFC的话&#xff0c;注册状态MD上报 regState: NOT_REG_MT_NOT…

IO进线程练习(用到了:文件IO 标准IO 多进程 exec进程转移 有名管道 无名管道)

1 利用文件IO读取文件数据存入链表&#xff0c;当触法ctrlc时将链表数据存入文件。 main.c #include"head.h" FILE*fp_w; linklist L; void handler(int sig){out_file(fp_w,L);printf("文件写入完成\n");exit(0); }int main(int argc, const char *argv…

一文读懂MySQL7大日志(slow、redo、undo、bin、relay、general、error)

Slow Log 简介 用于记录执行时间超过指定值的 SQL 语句的详细信息&#xff0c;多用于调试和监控。 配置 因为开启会略微影响性能&#xff0c;所以默认没有开启&#xff0c;所以需要配置。 查看是否开启 show variables like %slow%; ------------------------------------…

计算机找不到api-ms-win-core-path-l1-1-0的5种解决方法

在计算机使用过程中&#xff0c;我们可能会遇到各种问题&#xff0c;其中之一就是找不到某些系统文件。最近&#xff0c;许多用户反映他们在使用电脑时遇到了“找不到api-ms-win-core-path-l1-1-0文件”的问题。这个问题通常出现在Windows操作系统中&#xff0c;可能会影响到一…

Java外观模式源码剖析及使用场景

外观模式 一、介绍二、家庭影院项目案例使用三、Java API或框架中应用分析三、Spring框架ApplicationContext源码 一、介绍 外观模式(Facade Pattern)是一种结构型设计模式,它为子系统中的一组接口提供了一个统一的高层接口,使得子系统更加容易使用。外观模式定义了一个高层接…

leetcode:二叉树的左右子树反转的递归和迭代的C++实现

问题描述 给定一个二叉树&#xff0c;将其每个节点的左右子树进行反转。 解决方案 以下是 C 代码实现&#xff1a; TreeNode* invertTree(TreeNode* root) {if (root nullptr) {return nullptr;}// 交换当前节点的左右子树TreeNode* temp root->left;root->left r…

C语言转义字符:一文打尽

转义字符 1. 前言2. 预备知识2.1 打印格式2.2 进制转换2.3 ASCII码 3. 什么是转义字符4. 常见的转义字符4.1 \?4.2 \4.3 \"4.4 \\4.5 \dddddd表示1到3个八进制数字4.6 \xdddd表示1到2个十六进制数字4.7 其他转义字符 5. 一道笔试题6. 一个小插曲 1. 前言 大家好&#xf…

DFS和BFS以及练习题目(未完待续)

DFS和BFS 温馨提示&#xff1a;学习dfs之前最好先了解一下递归的思想。 递归思想 斐波那契 题目分析 题目代码 import java.util.Scanner; public class Main{static long dp[]; public static void main(String[] args) {Scanner scanner new Scanner(System.in);int t…

吴恩达deeplearning.ai:倾斜数据集的误差指标精确率、召回率

以下内容有任何不理解可以翻看我之前的博客哦&#xff1a;吴恩达deeplearning.ai专栏 文章目录 倾斜数据集的误差指标罕见病预测精确率和召回率 精确率和召回率的权衡精确率和召回率的矛盾关系 F1算法 倾斜数据集的误差指标 在神经网络中&#xff0c;如果你的数据集中正例和负…

CSS样式中长度单位含义解析:rpx、px、vw、vh、em、rem、pt

在 CSS 样式中&#xff0c;有几种常见的长度单位&#xff0c;包括 rpx 、 px 、 vw 和 vh 等&#xff0c;含义解析如下&#xff1a; 1 . rpx &#xff08;响应像素&#xff09;&#xff1a; 是微信小程序中的一种相对长度单位&#xff0c;可以根据屏幕宽度进行自适应缩放。 1rp…

PTA 对于下列程序,正确的是() 。void f(int *p){ *p = 5;}int main(void){ int a, *p; a = 10;

对于下列程序&#xff0c;正确的是&#xff08;&#xff09; 。 void f(int *p) {*p 5; } int main(void) {int a, *p;a 10;p &a;f(p);printf(“%d”, (*p));return 0; }A.5 B.6 C.10 D.11 答&#xff1a;A 解析&#xff1a;这里考察当是指针作为函数的参数。这里将 p …

python脚本批量关闭exe文件

python脚本批量关闭exe文件 1、安装psutil库 pip install psutil2、示例代码 """ @contact: 微信 1257309054 @file: main.py @time: 2024/3/9 21:16 @author: LDC """ import os import time import psutildef is_process_running(process_n…

docker删除、停止所有容器或镜像

docker删除、停止所有容器或镜像 列出所有的容器 ID docker ps -aq停止所有容器 docker stop $(docker ps -aq)删除所有容器 docker rm $(docker ps -aq)删除所有镜像 docker rmi $(docker images -aq)

算法之对于算法的想法

小插曲 很早就参加过头条的面试&#xff0c;真的很早以前&#xff0c;头条那时还不是很火&#xff0c;自己的首先也不是头条。就知道对算法特别的重视&#xff0c;现实也的确如此。记得还是面对面的面试&#xff0c; 忘记一面的算法题目了&#xff0c;不过当时是有思路的&…

Codeforces Round 719 (Div. 3)除F2题外补题报告

Codeforces Round 719 Div. 3 除F2题外补题报告 得分情况补题情况错题分析C题题目大意初次思路正解思路正解代码错误原因 D题题目大意初次思路正解思路正解代码错误原因 E题题目大意初次思路正解思路正解代码 F1题题目大意正解思路正解代码 G题题目大意正解思路正解代码 得分情…

EDA 许可证调度

背景 在芯片设计和HPC行业EDA软件的许可证是很昂贵的数据资源&#xff0c;如何高效利用许可证以及计算资源是系统管理员需要认真思考的问题。 商用解决方案 LSF是芯片和HPC行业流行的调度方案&#xff0c;LSF产品家族包含了许可证调度的功能。它提供了许可证管理和调度功能&…

开发知识点-C++之win32与NT内核

win32 Windows MFC编程 常用API汇总EnumWindows()函数UpdateData()函数static与 单例 设计模式函数原型:BOOL WINAPI SetConsoleTitle(__in LPCTSTR lpConsoleTitle);HWND 是一个基本类型 表示窗口句柄FindWindow函数SendMessage函数 将指定的消息发送到一个或多个窗口PostMes…

Matlab|配电网智能软开关(sop)规划模型

目录 1 主要内容 目标函数 2 部分程序 3 程序结果 3.1 sop选址定容优化模型 3.2 对比算例&#xff08;不含sop&#xff09; 4 下载链接 1 主要内容 该程序参考文献《基于改进灵敏度分析的有源配电网智能软开关优化配置》&#xff0c;采用二阶锥算法&#xff0c;以改进的…

蓝桥杯-最大距离

根据题意直接写出来就行。 简单题就话不多说上代码了 #include <iostream> #include <cmath> using namespace std; int main() {int n;cin>>n;int a[1000]{0};for(int i0;i<n;i){cin>>a[i];}int temp 0;int dis 0;for(int i0;i<n-1;i)for(…