# 小型注册与登录系统实现教程


背景介绍

在现代应用程序中,用户验证是系统安全性和数据管理的重要环节。本系统采用HTML、CSS和JavaScript实现表单验证逻辑,并通过JSON存储验证结果,确保数据安全与可追踪性。

思路分析

  1. 表单验证逻辑:通过输入用户名和密码的字段验证规则,如密码长度≥6位、包含数字。
  2. 数据存储与响应:使用JSON记录验证结果,实现数据持久化与状态更新。
  3. 事件响应机制:绑定用户名和密码输入事件,验证结果通过DOM更新页面状态。

代码实现

1. HTML表单结构

<!DOCTYPE html>
<html>
<head>
    <title>注册与登录系统</title>
    <style>
        body {
            font-family: Arial, sans-serif;
            padding: 20px;
            background-color: #f4f4f4;
        }
        form {
            width: 300px;
            margin: 20px auto;
            background: #fff;
            padding: 20px;
        }
        input, textarea {
            width: 100%;
            margin: 5px 0;
            padding: 8px;
            box-sizing: border-box;
        }
        button {
            background-color: #4CAF50;
            color: white;
            padding: 10px 15px;
            border: none;
            cursor: pointer;
        }
        button:hover {
            background-color: #33768f;
        }
    </style>
</head>
<body>

<div class="container">
    <h2>注册与登录系统</h2>
    <form id="loginForm">
        <input type="text" id="username" placeholder="用户名" required>
        <input type="password" id="password" placeholder="密码" required>
        <button type="submit">登录</button>
    </form>
</div>

<script>
    // 本地存储验证结果
    const localStorage = window.localStorage;
    const validationResults = {
        username: false,
        password: false,
        status: 'success'
    };

    // 表单验证逻辑
    document.getElementById('loginForm').addEventListener('submit', function(e) {
        e.preventDefault();
        const username = document.getElementById('username').value.trim();
        const password = document.getElementById('password').value.trim();

        // 简单验证逻辑
        if (username.length < 4) {
            document.getElementById('username').setValidity(true);
            document.getElementById('password').setValidity(true);
            validationResults.status = 'failure';
        } else {
            validationResults.status = 'success';
            localStorage.setItem('loginValidation', JSON.stringify(validationResults));
            document.getElementById('loginForm').reset();
        }

        // 更新页面状态
        document.getElementById('status').textContent = validationResults.status;
    });

    // 本地存储验证结果
    function saveValidationResults() {
        localStorage.setItem('loginValidation', JSON.stringify(validationResults));
    }

    // 从本地存储获取验证结果
    function loadValidationResults() {
        const result = localStorage.getItem('loginValidation');
        validationResults.status = result ? JSON.parse(result).status : 'success';
        updateUI();
    }

    // 更新UI
    function updateUI() {
        document.getElementById('status').textContent = validationResults.status;
    }

    // 调用验证结果
    document.addEventListener('DOMContentLoaded', loadValidationResults);
</script>

</body>
</html>

总结

本系统通过HTML表单验证、JavaScript状态更新和JSON数据存储实现了注册与登录功能。数据结构选择JSON确保了验证结果的持久性和可追踪性,验证逻辑清晰且易于扩展。事件响应机制确保用户输入被实时处理,提升用户体验。