前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用原生 JavaScript 手写一个高效的表单验证系统

使用原生 JavaScript 手写一个高效的表单验证系统

作者头像
前端达人
发布2024-06-14 14:04:35
1080
发布2024-06-14 14:04:35
举报
文章被收录于专栏:前端达人前端达人
在开发Web应用时,表单验证是一个必不可少的功能,能够帮助我们确保用户输入的数据是有效的。在这篇文章中,我们将介绍一个简单但功能齐全的表单验证项目,适合初学者学习和掌握。

项目需求

我们需要实现一个注册表单,其中包括以下几个字段:

  • 用户名
  • 邮箱
  • 密码
  • 确认密码

表单需要进行以下验证:

  1. 所有字段都是必填项。
  2. 用户名长度应在3到15个字符之间。
  3. 密码长度应在6到25个字符之间。
  4. 邮箱格式应有效。
  5. 密码和确认密码必须匹配。

案例展示

以下是我们将实现的表单页面截图:

如何实现

我们将使用HTML、CSS和JavaScript来实现这个表单验证功能。首先,让我们看看HTML代码:

代码语言:javascript
复制
<!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样式,使我们的表单更美观:

代码语言:javascript
复制
@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代码,负责表单验证的逻辑:

代码语言: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代码解析

  1. 获取表单元素:通过getElementById获取表单和各个输入字段的引用。
  2. 显示错误信息showError函数用于显示错误信息,改变表单控件的样式并显示具体的错误信息。
  3. 显示成功信息showSuccess函数用于显示成功信息,改变表单控件的样式为成功状态。
  4. 验证邮箱格式checkEmail函数使用正则表达式验证邮箱格式是否有效。
  5. 检查必填字段checkRequired函数遍历所有输入字段,检查是否为空,并调用showErrorshowSuccess函数。
  6. 检查输入长度checkLength函数检查输入的字符长度是否在指定范围内。
  7. 检查密码匹配checkPasswordsMatch函数检查两个密码字段是否一致。
  8. 获取字段名称getFieldName函数将输入字段的ID转换为首字母大写的字段名称。
  9. 事件监听:为表单添加提交事件监听器

知识点总结

  • 表单验证:了解如何使用JavaScript进行表单验证,确保用户输入的数据是有效的。
  • 正则表达式:学习如何使用正则表达式验证邮箱格式。
  • 事件监听:理解如何使用事件监听器处理表单提交事件。
  • 动态样式:通过JavaScript动态添加和移除CSS类,实现表单的错误和成功提示。

结束

希望这篇文章对你有所帮助!如果你在实现过程中遇到任何问题,欢迎在评论区留言,我会尽快回复你。或者你有更好的解决方案,也欢迎分享出来,让我们一起进步!

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-06-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端达人 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 项目需求
  • 案例展示
  • 如何实现
    • HTML代码解析
      • CSS代码解析
        • JavaScript代码解析
        • 知识点总结
        • 结束
        相关产品与服务
        容器服务
        腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档