表单验证实战:HTML、CSS和JavaScript完整教程
创作时间:
2025-01-22 05:38:49
作者:
@小白创作中心
表单验证实战:HTML、CSS和JavaScript完整教程
在开发Web应用时,表单验证是一个必不可少的功能,能够帮助我们确保用户输入的数据是有效的。在这篇文章中,我们将介绍一个简单但功能齐全的表单验证项目,适合初学者学习和掌握。
项目需求
我们需要实现一个注册表单,其中包括以下几个字段:
- 用户名
- 邮箱
- 密码
- 确认密码
表单需要进行以下验证:
- 所有字段都是必填项。
- 用户名长度应在3到15个字符之间。
- 密码长度应在6到25个字符之间。
- 邮箱格式应有效。
- 密码和确认密码必须匹配。
案例展示
以下是我们将实现的表单页面截图:
如何实现
我们将使用HTML、CSS和JavaScript来实现这个表单验证功能。首先,让我们看看HTML代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Form Validator</title>
<link rel="stylesheet" href="style.css">
</head>
<body>
<div class="container">
<form id="form" class="form">
<h2>Register With Us</h2>
<div class="form-control">
<label for="username">Username</label>
<input type="text" id="username" placeholder="Enter username">
<small>Error message</small>
</div>
<div class="form-control">
<label for="email">Email</label>
<input type="text" id="email" placeholder="Enter email">
<small>Error message</small>
</div>
<div class="form-control">
<label for="password">Password</label>
<input type="password" id="password" placeholder="Enter password">
<small>Error message</small>
</div>
<div class="form-control">
<label for="password2">Confirm Password</label>
<input type="password" id="password2" placeholder="Enter password again">
<small>Error message</small>
</div>
<button type="submit">Submit</button>
</form>
</div>
<script src="script.js"></script>
</body>
</html>
HTML代码解析
- 表单结构:我们定义了一个包含用户名、邮箱、密码和确认密码的表单。
- 输入字段:每个输入字段都包含一个标签和一个小的错误消息提示。
然后是CSS样式,使我们的表单更美观:
@import url('https://fonts.googleapis.com/css?family=Open+Sans&display=swap');
:root {
--success-color: #2ecc71;
--error-color: #e74c3c;
}
* {
box-sizing: border-box;
}
body {
background-color: #f9fafb;
font-family: 'Open Sans', sans-serif;
display: flex;
align-items: center;
justify-content: center;
min-height: 100vh;
margin: 0;
}
.container {
background-color: #fff;
border-radius: 5px;
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
width: 400px;
}
h2 {
text-align: center;
margin: 0 0 20px;
}
.form {
padding: 30px 40px;
}
.form-control {
margin-bottom: 10px;
padding-bottom: 20px;
position: relative;
}
.form-control label {
color: #777;
display: block;
margin-bottom: 5px;
}
.form-control input {
border: 2px solid #f0f0f0;
border-radius: 4px;
display: block;
width: 100%;
padding: 10px;
font-size: 14px;
}
.form-control input:focus {
outline: 0;
border-color: #777;
}
.form-control.success input {
border-color: var(--success-color);
}
.form-control.error input {
border-color: var(--error-color);
}
.form-control small {
color: var(--error-color);
position: absolute;
bottom: 0;
left: 0;
visibility: hidden;
}
.form-control.error small {
visibility: visible;
}
.form button {
cursor: pointer;
background-color: #3498db;
border: 2px solid #3498db;
border-radius: 4px;
color: #fff;
display: block;
font-size: 16px;
padding: 10px;
margin-top: 20px;
width: 100%;
}
CSS代码解析
- 全局样式:设置基本的样式,如字体、背景颜色和盒模型。
- 表单样式:定义表单的容器、标题、表单控件和按钮的样式。
- 表单验证样式:使用CSS类显示输入框的成功和错误状态。
最后是JavaScript代码,负责表单验证的逻辑:
const form = document.getElementById('form');
const username = document.getElementById('username');
const email = document.getElementById('email');
const password = document.getElementById('password');
const password2 = document.getElementById('password2');
// 显示错误信息
function showError(input, message) {
const formControl = input.parentElement;
formControl.className = 'form-control error';
const small = formControl.querySelector('small');
small.innerText = message;
}
// 显示成功信息
function showSuccess(input) {
const formControl = input.parentElement;
formControl.className = 'form-control success';
}
// 验证邮箱格式
function checkEmail(input) {
const re = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
if (re.test(input.value.trim())) {
showSuccess(input);
} else {
showError(input, 'Email is not valid');
}
}
// 检查必填字段
function checkRequired(inputArr) {
inputArr.forEach(function(input) {
if (input.value.trim() === '') {
showError(input, `${getFieldName(input)} is required`);
} else {
showSuccess(input);
}
});
}
// 检查输入长度
function checkLength(input, min, max) {
if (input.value.length < min) {
showError(
input,
`${getFieldName(input)} must be at least ${min} characters`
);
} else if (input.value.length > max) {
showError(
input,
`${getFieldName(input)} must be less than ${max} characters`
);
} else {
showSuccess(input);
}
}
// 检查密码匹配
function checkPasswordsMatch(input1, input2) {
if (input1.value !== input2.value) {
showError(input2, 'Passwords do not match');
}
}
// 获取字段名称
function getFieldName(input) {
return input.id.charAt(0).toUpperCase() + input.id.slice(1);
}
// 事件监听
form.addEventListener('submit', function(e) {
e.preventDefault();
checkRequired([username, email, password, password2]);
checkLength(username, 3, 15);
checkLength(password, 6, 25);
checkEmail(email);
checkPasswordsMatch(password, password2);
});
JavaScript代码解析
- 获取表单元素:通过
getElementById获取表单和各个输入字段的引用。 - 显示错误信息:
showError函数用于显示错误信息,改变表单控件的样式并显示具体的错误信息。 - 显示成功信息:
showSuccess函数用于显示成功信息,改变表单控件的样式为成功状态。 - 验证邮箱格式:
checkEmail函数使用正则表达式验证邮箱格式是否有效。 - 检查必填字段:
checkRequired函数遍历所有输入字段,检查是否为空,并调用showError或showSuccess函数。 - 检查输入长度:
checkLength函数检查输入的字符长度是否在指定范围内。 - 检查密码匹配:
checkPasswordsMatch函数检查两个密码字段是否一致。 - 获取字段名称:
getFieldName函数将输入字段的ID转换为首字母大写的字段名称。 - 事件监听:为表单添加提交事件监听器
知识点总结
- 表单验证:了解如何使用JavaScript进行表单验证,确保用户输入的数据是有效的。
- 正则表达式:学习如何使用正则表达式验证邮箱格式。
- 事件监听:理解如何使用事件监听器处理表单提交事件。
- 动态样式:通过JavaScript动态添加和移除CSS类,实现表单的错误和成功提示。
结束
希望这篇文章对你有所帮助!如果你在实现过程中遇到任何问题,欢迎在评论区留言,我会尽快回复你。或者你有更好的解决方案,也欢迎分享出来,让我们一起进步!
热门推荐
厨余垃圾变环保利器,详解环保酵素的制作与应用
厨余垃圾发酵成宝,环保酵素让家庭清洁更绿色
从厨余到肥料:环保酵素开辟有机农业新路径
乐谱架选购指南:尺寸、重量与使用场景全攻略
陈建斌:用细节演绎帝王,从《甄嬛传》到《乔家大院》
建筑幕墙工程验收标准:材料检验与施工质量控制要点
从预验收到备案:建设工程验收完整流程详解
项目验收全面解析:作用、流程与未来趋势
金融信创验收标准出台,专家详解五大问题与应对之道
亚龙湾游泳全攻略:安全须知、时间及周边景点推荐
金马三冠王陈建斌:恶搞争议中的实力坚守
从《新三国》争议到金马封王:陈建斌的演艺蜕变
股指期货交割日全解析:市场影响与应对策略
黑石集团CEO苏世民:当前投资者面临的最大风险是什么?
期货交易新手必读:三大规则与三大风险详解
解码期货投资:从杠杆机遇到四大风险防范
施工现场大仓库如何管理
加筋挡土墙失稳的4个现象及防治措施
板与柱交接处加强筋的设置要点
10种幕墙工程施工工艺详解
装配式墙体的安装方式与施工效率
从“四郎”到金马奖得主:陈建斌的演艺之路
蒋勤勤获亚洲影后,感谢丈夫18年相伴相惜
AI换脸热潮下的网络安全警示
AI反诈骗白皮书:揭秘AI诈骗黑幕
四川新网银行教你防范AI诈骗:从最新案例看风险要点
富春山居图艺术特色:从传统山水到数字艺术的创新转化
时隔360年,《富春山居图》在台北故宫实现合璧展出,见证两岸文化融合
《富春山居图》:黄公望的山水长卷与两岸文化交融
柳州反诈宣传日:科技助力识破金融诈骗新套路