登录/注册

目录

 1.HTML

2.CSS

 3.JS

4.资源

5.运行结果

 6.下载链接

7.注意事项 


 1.HTML

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>注册</title><link rel="stylesheet" href="../css/register.css">
</head>
<body><div class="register"><div class="cont"><ul class="list"><li><span>用户名</span><input type="text" class="userName"><img src="../image/sure.png" alt="必填"></li><li><span>Email</span><input type="email" class="email"><img src="../image/sure.png" alt="必填"></li><li><span>密码</span><input type="password" class="password"><img src="../image/sure.png" alt="必填"></li><li class="qiang"><span>密码强度</span><p><span class="weak">弱</span><span class="medium">中</span><span class="strong">强</span></p></li><li><span>确认密码</span><input type="password" class="passwordTrue"><img src="../image/sure.png" alt="必填"></li><li><span>MSN</span><input type="text" class="msn"></li><li><span>QQ</span><input type="text" class="qq"></li><li><span>办公电话</span><input type="text" class="tel"></li><li><span>家庭电话</span><input type="text" class="phone"></li><li><span>手机</span><input type="text" class="mobile"></li><li class="yan"><span>验证码</span><input type="text"><p class="yanMa">J6EP</p></li><li><span></span><input type="checkbox" class="agree"><p>我已看过并接受《<a href="##">用户协议</a>》</p></li><li><span></span><button class="btn">立即注册</button></li></ul></div></div>
</body>
</html>
<script src="../js/register.js"></script>

2.CSS

*{margin: 0;padding: 0;}
ul,li,ol{list-style-type: none;}
button{cursor: pointer;border: none;background: rgba(255, 255, 255, 1);}
.register{width: 100%;height: 100vh;display: flex;justify-content: center;align-items: center;
}
.cont{width: 320px;height: 450px;background: #fbfbfb;display: flex;flex-direction: column;justify-content: center;align-items: center;
}
.list{width: 270px;
}
.list li{width: 100%;height: 20px;display: flex;align-items: center;margin-bottom: 10px;font-size: 12px;
}
.list li span{width: 60px;height: 100%;line-height: 20px;text-align: right;margin-right: 10px;
}
.list li input{/* width: 180px; */height: 100%;border: 1px #ccc solid;
}
.list li img{width: 10px;height: 10px;margin-left: 10px;
}
.list li p{margin-left: 10px;
}
.list .qiang p{width: 120px;display: flex;align-items: center;justify-content: space-around;
}
.list .yan input{width: 80px;
}
.list .yan p{width: 80px;height: 100%;line-height: 20px;text-align: center;border: 1px #ccc solid;background: url(../image/yan.png) no-repeat 0 0/100% 100%;color: #fff;
}
.btn{width: 100px;height: 40px;background: #4da4d2;color: #fff;margin-top: 10px;border-radius: 5px;
}
.yanMa{cursor: pointer;
}

 3.JS

let btn = document.querySelector('.btn');let userName = document.querySelector('.userName');let email = document.querySelector('.email');let password = document.querySelector('.password');let passwordTrue = document.querySelector('.passwordTrue');let msn = document.querySelector('.msn');let qq = document.querySelector('.qq');let tel = document.querySelector('.tel');let phone = document.querySelector('.phone');let mobile = document.querySelector('.mobile');let yan = document.querySelector('.yan input');let yanMa = document.querySelector('.yanMa');let agree = document.querySelector('.agree');let weak = document.querySelector('.weak');let medium = document.querySelector('.medium');let strong = document.querySelector('.strong');// 密码强度function checkPasswordStrength(password) {if(password.length<5){alert('最少输入6位密码');}else if(password.length>25){alert('最多输入26位密码');}else{let code=0;const hasNumber = /\d/;  // 包含数字const hasLetter = /[a-zA-Z]/;  // 包含字母const hasSymbol = /[!@#$%^&*(),.?":{}|<>]/;  // 包含特殊字符if (hasNumber.test(password)) code++;if (hasLetter.test(password)) code++;if (hasSymbol.test(password)) code++;// 检查密码强度if (code==1) {weak.style.color='#f00';medium.style.color = '#000';strong.style.color = '#000';} else if (code==2) {weak.style.color='#000';medium.style.color = '#f00';strong.style.color = '#000';} else if (code==3) {weak.style.color='#000';medium.style.color = '#000';strong.style.color = '#f00';} else {weak.style.color='#000';medium.style.color = '#000';strong.style.color = '#000';}}};// 失焦判断密码强度password.onblur=function(){checkPasswordStrength(password.value);  }// 验证码function yanZheng(){// 包含所有可能的字符const characters = '0123456789abcdefghijklmnopqrstuvwxyz';// 生成四位验证码let verificationCode = '';for (let i = 0; i < 4; i++) {const randomIndex = Math.floor(Math.random() * characters.length);verificationCode += characters.charAt(randomIndex);}yanMa.innerHTML=verificationCode.toUpperCase();};yanZheng();// 点击验证码刷新验证码yanMa.onclick=function(){yanZheng();   };// 点击注册按钮btn.onclick=function(){let yanEmail = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/;let yanTel = /^1[3-9]\d{9}$/;let dataObj={userName:userName.value,email:email.value,password:password.value,msn:msn.value,qq:qq.value,tel:tel.value,phone:phone.value,mobile:mobile.value,};yan.value=yan.value.toUpperCase();if(userName.value==''){alert('请输入用户名');}else if(email.value==''){alert('请输入Email');}else if(!yanEmail.test(email.value)){alert('请输入正确的Email');}else if(password.value==''){alert('请输入密码');}else if(passwordTrue.value==''){alert('请确认密码');}else if(password.value!=passwordTrue.value){alert('两次密码输入不一致,请重新输入。')}else if(yan.value==''||yan.value!=yanMa.innerHTML){console.log(yan.value,yanMa.innerHTML);if(confirm('验证码输入不正确,请重新输入')){yanZheng();}else{yanZheng();}}else if(!agree.checked){if(confirm('请同意用户协议')){agree.checked=!agree.checked;}else{}}else{fetch('http://localhost:8080/api/register',{method: 'POST',headers: {'Content-Type': 'application/json', // 设置请求头的 Content-Type},body: JSON.stringify(dataObj)}).then(response => response.json()).then(data => {console.log(data);if(data.code==200){alert('注册成功');}}).catch(error => {console.error('Error:', error);});}};

4.资源

5.运行结果

 6.下载链接

在此下载压缩包

【免费】登录、注册的建议通用模板资源-CSDN文库

7.注意事项 

此压缩包 包含前后端简单交互,后端需要用到Node.js,运行口令 nodemon app.js 

或者在serve文件夹直接运行run.bat文件,运行成功后打开html即可。注意:run.bat运行成功后不要退出cmd。

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

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

相关文章

Zabbix配置JAVA JMX监控

JAVA JMX监控简介 官方文档&#xff1a;https://www.zabbix.com/documentation/current/zh/manual/concepts/java Zabbix Java gateway以 Zabbix 守护进程方式原生支持监控 JMX 应用程序。Zabbix Java gateway 的守护进程是用 Java 编写。为了在特定主机上找到 JMX 计数器的值…

Java设计模式的7个设计原则

Java设计模式的7个设计原则是面向对象设计领域中的重要指导方针&#xff0c;它们旨在提高软件系统的可维护性、可扩展性、可复用性和灵活性。以下是这7个设计原则的详细解释&#xff1a; 1. 开闭原则&#xff08;Open-Closed Principle, OCP&#xff09; 定义&#xff1a;一个…

LCM通讯的使用

本文主要介绍LCM通讯的基本使用&#xff0c;内容主要整理自官网 https://lcm-proj.github.io/lcm/index.html LCM&#xff0c;即Library for Communication and Marshalling&#xff0c;是一组用于消息传递与数据封装的库和工具&#xff0c;它主要的面向对象是要求高带宽、低延…

Cesium--获取当前相机中心与地面的射线焦点

本文记录获取当前相机中心与地面的射线焦点的方法&#xff0c;可用于视角缩放过程中&#xff0c;控制视角自动平滑切换到二维等场景&#xff1a; 方法一定是视角中心能与地面有交集&#xff0c;如果对着地平线或对着天空肯定是没效果的。直接放代码&#xff1a; //调整相机到正…

Objective-C 自定义渐变色Slider

文章目录 一、前情概要二、具体实现 一、前情概要 系统提供UISlider&#xff0c;但在开发过程中经常需要自定义&#xff0c;本次需求内容是实现一个拥有渐变色的滑动条&#xff0c;且渐变色随着手指touch的位置不同改变区域&#xff0c;类似如下 可以使用CAGradientLayer实现渐…

利用宝塔安装一套linux开发环境

更新yum&#xff0c;并且更换阿里镜像源 删除yum文件 cd /etc/yum.repos.d/ 进入yum核心目录 ls sun.repo rm -rf * 删除之前配置的本地源 ls 配置阿里镜像源 wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo 配置扩展包 wge…

paloalto防火墙CLI修改MGT IP

怎么样通过Cli修改MGT口的IP、掩码、网关、DNS呢&#xff1f; 1&#xff09;console连接上CLi&#xff0c;输入configure进入系统视图 输入exit&#xff0c;退出到用户视图 2&#xff09;在CLI修改带外管理MGT的IP地址、掩码、网关、DNS&#xff0c;默认带外管理是开启https、…

[Elasticsearch]ES近似实时搜索的原因|ES非实时搜索的原因|ES Near real-time search

Elasticsearch-专栏&#x1f448;️ 往期回顾&#xff1a; ES单一查询定义&#x1f448;️ ES深分页问题&#x1f448;️ ES商城搜索实战&#x1f448;️ ES环境搭建:单节点模式/集群模式&#x1f448;️ ES开启认证&#x1f448;️ 近似实时搜索&#xff08;Near real-t…

FlinkModule加载HiveModule异常

HiveModule这个模块加载不出来 加在不出来这个模块&#xff0c;网上查说是要加下面这个依赖 <dependency><groupId>org.apache.flink</groupId><artifactId>flink-connector-hive_${scala.binary.version}</artifactId><version>${flink.…

Elasticsearch基础概念

Elasticsearch 是一款开源的,ESTful风格的 分布式搜索、存储、分析引擎; 常见的使用场景 网站搜索,代码搜索等日志管理与分析,应用系统性能分析,安全指标监控等数据库同步,将数据库某个表的数据同步到elasticsearch上然后提供搜索服务 ES基本概念 文档 我们向elasticsearch存…

【活动预告】Apache IoTDB TsFile 智慧能源应用“上会”啦!

2024 年&#xff0c;站在中国数字经济产业升级和数据要素市场化建设的时代交汇点上&#xff0c;为进一步推动全球数据库产业进步&#xff0c;由中国通信标准化协会、大数据技术标准推进委员会主办的“2024 可信数据库发展大会”将于 2024 年 7 月 16-17 日&#xff0c;在北京朝…

跟着李沐学AI:Softmax回归

回归 vs 分类 回归用于估计一个连续值 分类用于预测一个离散类别 两个经典的数据集&#xff1a; MNIST数据集&#xff1a; MNIST&#xff08;Modified National Institute of Standards and Technology&#xff09;数据集是一个广泛应用于机器学习和深度学习领域的手写数字…

车载视频监控管理方案:无人驾驶出租车安全出行的保障

近日&#xff0c;无人驾驶出租车“萝卜快跑”在武汉开放载人测试成为热门话题。随着科技的飞速发展&#xff0c;无人驾驶技术已逐渐从概念走向现实&#xff0c;特别是在出租车行业中&#xff0c;无人驾驶出租车的推出将为公众提供更为安全、便捷、高效的出行服务。 视频监控技…

【Linux杂货铺】2.进程优先级

1.进程优先级基本概念 进程优先级是操作系统中用于确定进程调度顺序的一个指标。每个进程都会被分配一个优先级&#xff0c;优先级较高的进程会在调度时优先被执行。进程优先级的设定通常根据进程的重要性、紧急程度、资源需求等因素来确定。操作系统会根据进程的优先级来决定进…

免费开源的工业物联网(IoT)解决方案

什么是 IoT&#xff1f; 物联网 (IoT) 是指由实体设备、车辆、电器和其他实体对象组成的网络&#xff0c;这些实体对象内嵌传感器、软件和网络连接&#xff0c;可以收集和共享数据。 IoT 设备&#xff08;也称为“智能对象”&#xff09;范围广泛&#xff0c;包括智能恒温器等…

PHP企业工商年报大师微信小程序系统源码

&#x1f31f;轻松搞定年报难题&#xff01;&#x1f4bc; &#x1f680;【一键直达&#xff0c;年报不再繁琐】 还在为每年的企业工商年报而头疼吗&#xff1f;繁琐的表格、复杂的流程&#xff0c;让人望而却步&#xff1f;现在有了“企业工商年报大师”微信小程序&#xff…

Docker:基础概念、架构与网络模式详解

1.Docker的基本概念 1.1.什么是docker Docker是一个用于开发,交付和运行应用程序的开放平台.docker使您能够将应用程序域基础框架分开,以便你可以快速开发交付软件.使用docker,你可以管理你的基础架构以管理应用程序相同的方式.通过利用docker用于交付,测试和部署代码的方法,你…

解决Ubuntu 22.04 vscode搜狗拼音输入无法输入中文

关闭vscode 编辑~/.bashrc&#xff0c;添加以下内容 export GTK_IM_MODULExim export QT_IM_MODULExim export XMODIFIERSimfcitx source ~/.bashrc && code 重新加载环境变量后启动code&#xff0c;即可以正常使用搜狗拼音输入法了

MongoDB - 查询操作符:比较查询、逻辑查询、元素查询、数组查询

文章目录 1. 构造数据2. MongoDB 比较查询操作符1. $eq 等于1.1 等于指定值1.2 嵌入式文档中的字段等于某个值1.3 数组元素等于某个值1.4 数组元素等于数组值 2. $ne 不等于3. $gt 大于3.1 匹配文档字段3.2 根据嵌入式文档字段执行更新 4. $gte 大于等于5. $lt 小于6. $lte 小于…

java内部类的本质

定义在类内部&#xff0c;可以实现对外部完全隐藏&#xff0c;可以有更好的封装性&#xff0c;代码实现上也往往更为简洁。 内部类可以方便地访问外部类的私有变量&#xff0c;可以声明为private从而实现对外完全隐藏。 在Java中&#xff0c;根据定义的位置和方式不同&#xf…