HTML 部分:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>欢迎注册</title>
<link rel="stylesheet" href="css/register.css">
</head>
<body>
<div class="form-div">
<div class="reg-content">
<h1>欢迎注册</h1>
<span>已有账号?</span> <a href="#">登录</a>
</div>
<form id="reg-form" action="#" method="get">
<table>
<tr>
<td>用户名</td>
<td class="inputs">
<input name="username" type="text" id="username">
<br>
<span id="username_err" class="err_msg" style="display: none;">用户不太受欢迎</span>
</td>
</tr>
<tr>
<td>密 码</td>
<td class="inputs">
<input type="password" name="password" id="password">
<br>
<span id="password_err" class="err_msg" style="display: none;">密码格式错误</span>
</td>
</tr>
<tr>
<td>手机号</td>
<td class="inputs"><input name="tel" type="text" id="tel">
<br>
<span id="tel_err" class="err_msg" style="display: none;">手机号格式有误</span>
</td>
</tr>
</table>
<div class="buttons">
<input value="注册" type="submit" id="reg_btn">
</div>
<br class="clear">
</form>
</div>
</body>
<script>
/* 用户名的验证 */
// 1.验证用户名是否符合规则
// 1.1获取用户名的输入框
var usernameInput = document.getElementById("username");
//1.2绑定onblur 事件 失去焦点
usernameInput.onblur = checkUsername;
function checkUsername(){
//1.3获取用户输入的用户名
var username = usernameInput.value.trim();
// alert(username);
// 1.4判断用户名是否符合规则:6-12
var flag = username.length>=6 && username.length<=12;
if(flag){
//符合规则
document.getElementById("username_err").style.display= 'none';
}else{
//不符合规则
document.getElementById("username_err").style.display = '';
}
return flag;
}
/* 密码的验证 */
// 1.验证密码是否符合规则
// 1.1获取密码的输入框
var usernameInput = document.getElementById("password");
//1.2绑定onblur 事件 失去焦点
usernameInput.onblur = checkPassword;
function checkPassword(){
//1.3获取用户输入的密码
var password = usernameInput.value.trim();
// alert(username);
// 1.4判断密码是否符合规则:6-12
var flag = password.length>=6 && password.length<=12;
if(flag){
//符合规则
document.getElementById("password_err").style.display= 'none';
}else{
//不符合规则
document.getElementById("password_err").style.display = '';
}
return flag;
}
/* 手机号的验证 */
// 1.验证手机号是否符合规则
// 1.1获取手机号的输入框
var usernameInput = document.getElementById("tel");
//1.2绑定onblur 事件 失去焦点
usernameInput.onblur = checkTepon;
function checkTepon() {
//1.3获取用户输入的手机号
var tel = usernameInput.value.trim();
// 记录结果
var flag =tel.length==11;
// alert(username);
// 1.4判断手机号是否符合规则:6-12
if(flag){
//符合规则
document.getElementById("tel_err").style.display= 'none';
}else{
//不符合规则
document.getElementById("tel_err").style.display = '';
}
return flag;
}
/*-------------------------------------------------------*/
//1.获取表单对象
var regForm = document.getElementById("reg-form");
//2.绑定onsubmint 事件
regForm.onsubmit=function(){
//3.挨个判断每一个表单项目都符合要求,如果有一个不符合,则返回 false
var flag =checkUsername()&&checkPassword()&&checkTepon();
return flag;
}
</script>
</html>
css部分代码:
/* 把我们所有标签的内外边距清零 */
*{
margin: 0;
padding: 0;
/* css3盒子模型 */
/* box-sizing: border-box; */
}
/* em 和 i 斜体文字不倾斜 */
em,i{
font-style: normal;
}
i{
font-style: normal;
}
/* 去掉li的小圆点 */
li{
list-style: none;
}
img{
/* border 0 照顾低版本浏览器 如果外面包含了连接会有边框的问题 */
border: 0;
/* 取消图片底侧有空白缝隙的问题 */
/* 垂直对齐中间 */
vertical-align: middle;
}
.buttons{
/* 当我们经过button 按钮的时候,鼠标变成小手 */
/* 光标指针 */
cursor: pointer;
}
a{
color: #666;
/* 文本装饰 */
text-decoration: none;
}
body{
background-image: url("../img/R-C.jpg");
text-align: center;
}
table{
border-collapse: collapse;
border-spacing: 0;
}
.reg-content{
text-align: center;
/* margin-bottom:10px; */
}
td{
padding: 0;
height: 100px;
text-align: center;
}
.inputs{
vertical-align: top;
}
.clear{
clear: both;
}
.clear:before, .clear::after{
content: "";
display: table;
}
.clear:after{
clear: both;
}
.form-div{
background-color: rgb(255, 255, 255,0.27);
border-radius: 10px;
border: 1px solid #aaa;
width: 424px;
margin-top: 150px;
margin-left: 1050px;
padding: 30px 0px 20px 0px;
font-size: 16px;
box-shadow: inset 0px 0px 10px rgba(255, 255, 255, 0.5),0px 0px 15px rgba(75, 75, 75, 0.3);
text-align: left;
}
.form-div input[type="text"],.form-div input[type="password"]{
width: 168px;
margin: 10px;
/* height: 30px; */
line-height: 30px;
font-size: 16px;
/* margin-right: 50px; */
margin-top: 35px;
border-radius:6px;
/* margin-top: 30px; */
}
.form-div input[type="submit"]{
width: 168px;
margin: 10px;
/* height: 30px; */
line-height: 20px;
font-size: 16px;
background-color:antiquewhite;
border-radius:9px;
}
.form-div input[type="checkbox"]{
margin: 20px 0 20px 10px;
}
.form-div input[type="button"],.form-div input[type="submit"]{
margin: 10px 0px 0 0;
}
.form-div table{
margin: 0 auto;
text-align: right;
color: rgba(64, 64, 64, 1.00);
}
.buttons{
text-align: center;
margin-left: 30px;
}
.err_msg{
color: aqua;
}
最终成果