背景介绍
在现代应用程序中,用户验证是系统安全性和数据管理的重要环节。本系统采用HTML、CSS和JavaScript实现表单验证逻辑,并通过JSON存储验证结果,确保数据安全与可追踪性。
思路分析
- 表单验证逻辑:通过输入用户名和密码的字段验证规则,如密码长度≥6位、包含数字。
- 数据存储与响应:使用JSON记录验证结果,实现数据持久化与状态更新。
- 事件响应机制:绑定用户名和密码输入事件,验证结果通过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确保了验证结果的持久性和可追踪性,验证逻辑清晰且易于扩展。事件响应机制确保用户输入被实时处理,提升用户体验。