DOM编程之表单验证
一、题目描述
- 用户名不能为空
- 用户名必须在6-14位之间
- 用户名只有数字和字母组成,不能含有其他符号(正则表达式)
- 密码和确认密码一致,邮箱地址合法
- 统一失去焦点验证
- 错误提示信息统一在span标签中提示,并且要求字体12号、红色
- 文本框再次获得焦点后,清空错误提示信息,如果文本框中数据不合法要求清空文本框的value
- 最终表单所有项均合法方可提交
二、测试用例
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>表单验证</title>
<style type="text/css">
span {
color: red;
font-size: 12px;
}
</style>
<script type="text/javascript">
window.onload = function() {
var usernameElt = document.getElementById("username");
usernameElt.onblur = function() {
var username = usernameElt.value;
username = username.trim();
usernameErrorSpan = document.getElementById("usernameError");
if (username === "") {
usernameErrorSpan.innerText = "用户名不能为空";
} else {
if (username.length < 6 || username.length > 14) {
usernameErrorSpan.innerText = "用户名长度必须在6-14";
} else {
var regExp = /^[A-Za-z0-9]+$/;
if (regExp.test(username)) {
} else {
usernameErrorSpan.innerText = "用户名只能由数字和字母组成";
}
}
}
}
usernameElt.onfocus = function() {
if (usernameErrorSpan.innerText != "") {
usernameElt.value = "";
}
usernameErrorSpan.innerText = "";
}
var pwdErrorSpan = document.getElementById("pwdError");
var userpwd2Elt = document.getElementById("userpwd2");
userpwd2Elt.onblur = function() {
var userpwdElt = document.getElementById("userpwd");
var userpwd = userpwdElt.value;
var userpwd2 = userpwd2Elt.value;
if (userpwd != userpwd2) {
pwdErrorSpan.innerText = "密码不一致";
} else {
}
}
userpwd2Elt.onfocus = function() {
if (pwdErrorSpan.innerText != "") {
userpwd2Elt.value = "";
}
pwdErrorSpan.innerText = "";
}
var emailSpan = document.getElementById("emailError");
var emailElt = document.getElementById("email");
emailElt.onblur = function() {
var email = emailElt.value;
var emailRegExp = /^([a-zA-Z]|[0-9])(\w|\-)+@[a-zA-Z0-9]+\.([a-zA-Z]{2,4})$/;
if (emailRegExp.test(email)) {
} else {
emailSpan.innerText = "邮箱地址不合法";
}
}
emailElt.onfocus = function() {
if (emailSpan.innerText != "") {
emailElt.value = "";
}
emailSpan.innerText = "";
}
var submitBtnElt = document.getElementById("submitBtn");
submitBtnElt.onclick = function() {
usernameElt.focus();
usernameElt.blur();
userpwd2Elt.focus();
userpwd2Elt.blur();
emailElt.focus();
emailElt.blur();
if (usernameErrorSpan.innerText == "" && pwdErrorSpan.innerText == "" && emailSpan.innerText == "") {
var userFormElt = document.getElementById("userForm");
userFormElt.submit();
}
}
}
</script>
</head>
<body>
<form id="userForm" action="#" method="get">
用户名<input type="text" name="username" id="username" /><span id="usernameError"></span><br>
密码<input type="text" name="userpwd" id="userpwd" /><br>
确认密码<input type="text" id="userpwd2" /><span id="pwdError"></span><br>
邮箱<input type="text" name="email" id="email" /><span id="emailError"></span><br>
<input type="button" value="注册" id="submitBtn" />
<input type="reset" value="重置" />
</form>
</body>
</html>