2020-09-24

web注册页面的表单校验


    我们每天都会见到不同web页面,各种注册页面相信大家也不陌生,不知道大家有没有留意过一件事情,就是当我们填完每一项内容,当鼠标离开当前输入框之后,对应的输入框后面就会提示我们输入的用户名或者密码是否符合规范,提醒我们做出相应的修改。这就是表单的校验,只有当输入项符合相应的规范后才会对服务器进行数据的提交。今天我们就来了解一下这项技术背后的原理以及代码的实现。

    今天的内容涉及是前端方面的知识,需要大家提前了解html、css、javascript相关的知识,当然如果大家这方面的知识比较薄弱,但是又比较感兴趣,那就在自己的电脑上跑一跑,相信对大家也是一种提升呢

首先,我们先来了解一下html、css、javascript在网页开发中的作用:

html:用于搭建基础网页,展示页面的内容。

css:用于美化页面,布局页面。

javascript:可以增强用户和html页面的交互过程,可以来控制html元素,让页面有一些动态的效果,增强用户的体验。


下面我会分别向大家展示纯html写出来的页面、html+css的页面和html+css+javascript的页面效果,让大家有更直观的体会!


html相关标签介绍:

    <form> 标签用于为用户输入创建 HTML 表单。
    表单能够包含 input 元素,比如文本字段、复选框、单选框、提交按钮等等。
    表单还可以包含 menus、textarea、fieldset、legend 和 label 元素。
    表单用于向服务器传输数据。

    <input> 标签用于搜集用户信息。
    根据不同的 type 属性值,输入字段拥有很多种形式。输入字段可以是文本字段、复选框、掩码后的文本控件、
    单选按钮、按钮等等。

    <table> 标签定义 HTML 表格。
    简单的 HTML 表格由 table 元素以及一个或多个 tr、th 或 td 元素组成。
    tr 元素定义表格行,th 元素定义表头,td 元素定义表格单元。
    更复杂的 HTML 表格也可能包括 caption、col、colgroup、thead、tfoot 以及 tbody 元素。

实现思想:
    1.由于table标签可以定义HTML表格,所以注册界面的布局我们使用table标签来实现。
    定义一个表格,里面包含用户名、密码、Email等信息以及对应的输入框。
    2.由于form标签用于将用户输入的信息向服务器端提交,所以我们将table嵌入在form标签内,
    从而实现用户数据的提交。
    
    
源码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>注册页面html</title>
</head>
<body>

<form action="#" method="post">

    <table width="30%" align="center" border="1px solid">
        <!--用户名-->
        <tr>
            <td>
                <label for="username">用户名</label>
            </td>
            <td>
                <input type="text" name="username" placeholder="请输入用户名" id="username">
            </td>
        </tr>
        <!--密码-->
        <tr>
            <td>
                <label for="password">密码</label>
            </td>
            <td>
                <input type="password" name="password" placeholder="请输入密码" id="password">
            </td>
        </tr>
        <!--Email-->
        <tr>
            <td>
                <label for="email">Email</label>
            </td>
            <td>
                <input type="email" name="email" placeholder="请输入Email" id="email">
            </td>
        </tr>
        <!--姓名-->
        <tr>
            <td>
                <label for="name">姓名</label>
            </td>
            <td>
                <input type="text" name="name" placeholder="请输入真实姓名" id="name">
            </td>
        </tr>
        <!--手机号-->
        <tr>
            <td>
                <label for="tel">手机号</label>
            </td>
            <td>
                <input type="number" name="tel" placeholder="请输入手机号" id="tel">
            </td>
        </tr>
        <!--性别-->
        <tr>
            <td>
                <label>性别</label>
            </td>
            <td>
                <input type="radio" name="gender"  value="male" checked>男
                <input type="radio" name="gender"  value="female" >女
            </td>
        </tr>
        <!--出生日期-->
        <tr>
            <td>
                <label for="birthday">出生日期</label>
            </td>
            <td>
                <input type="date" name="birthday" id="birthday">
            </td>
        </tr>
        <!--验证码-->
        <tr>
            <td>
                <label for="checkcode">验证码</label>
            </td>
            <td>
                <input type="text" name="checkcode" id="checkcode">
                <img src="img2/verify_code.jpg">
            </td>
        </tr>
        <!--注册-->
        <tr>
            <td colspan="2" align="center">
                <input type="submit" value="注册">
            </td>
        </tr>
    </table>

</form>


</body>
</html>

运行截图:
 

html+css:

    css用于页面的美化和布局的调整,这里我提供一些常用的选择器和属性,供大家参考,更多的与css相关的信息
    大家可以查看参考文档,上面有详细的介绍。
    
    选择器
    
    .class 选择器选取带有指定类 (class) 的元素。
    实例:
    为 class="hometown" 的所有 <p> 元素设置样式:
    p.hometown
    { 
        background-color:yellow;
    }
    
    #id 选择器为带有指定 id 的元素设置样式。
    实例
    为 id="firstname" 的元素设置样式:
    #firstname
    { 
        background-color:yellow;
    }
    
    element 选择器用于指定元素名称的所有元素。
    实例
    选择并设置所有 <p> 元素的样式:
    p
    { 
        background-color:yellow;
    }
    
    * 选择器选取所有元素。
    实例
    选取 <div> 元素内部的所有元素:
    div *
    { 
        background-color:yellow;
    }
    
    属性:
    color:设置文本的颜色。
    
    line-height:设置行高。
    
    text-align:规定文本的水平对齐方式。
    
    font-size:规定文本的字体尺寸。
    
    background:在一个声明中设置所有的背景属性。
    
    border:在一个声明中设置所有的边框属性。
    
    padding:在一个声明中设置所有内边距属性。
    
    margin:在一个声明中设置所有外边距属性。
    
    height:设置元素高度。
    
    width:设置元素的宽度。

源码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>注册页面css</title>

    <style>
        *{
            margin: 0px;
            padding: 0px;
            box-sizing: border-box;
        }

        body{
            background: url("img2/register_bg.png") no-repeat;
            width: 100%;
            height: 100%;
            padding-top: 25px;
        }

        .layout{
            width: 900px;
            height: 500px;
            background: white;
            border: 8px darkgrey solid;
            margin: auto;
        }

        .div1{
            /*border: 1px red solid;*/
            float: left;
            margin-left: 15px;
            margin-top: 20px;
        }

        .div1_1{
           color: gold;
            font-size:20px;
        }

        .div1_2{
            font-size: 20px;
            color: darkgrey;
        }

        .div2{
            /*border: 1px red solid;*/
            float: left;
            margin-left: 15px;
        }

        .td_left{
            text-align: right;
            height: 45px;
            color: darkgrey;
            width: 100px;
        }

        .td_right{
            padding-left: 50px;
        }

        #username,#password,#email,#name,#tel,#checkcode,#birthday{
            width: 251px;
            height: 32px;
            border-radius: 5px;
            border: darkgrey 1px solid;
            padding-left: 15px;
        }

        #checkcode{
            width: 120px;
        }

        .img{
            height: 32px;
            vertical-align: middle;
        }

        .btu_sub{
            width: 120px;
            height: 40px;
            border: gold 1px solid;
            background: gold;
        }

        .div3{
            /*border: 1px red solid;*/
            float: right;
            margin-top: 20px;
            margin-right: 15px;
        }

        .div3_1{
            font-size: 13px;
        }

        .div3_1_first{
          color: pink;
        }

    </style>

</head>
<body>

<div class="layout">
<div class="div1">
    <div class="div1_1">
        新用户注册
    </div>
    <div class="div1_2">
        USER REGISTER
    </div>
</div>

<div class="div2">
<form action="#" method="post" class="form">

    <table class="table">
        <!--用户名-->
        <tr>
            <td class="td_left">
                <label for="username">用户名</label>
            </td>
            <td class="td_right">
                <input type="text" name="username" placeholder="请输入用户名" id="username">
            </td>
        </tr>
        <!--密码-->
        <tr>
            <td class="td_left">
                <label for="password">密码</label>
            </td>
            <td class="td_right">
                <input type="password" name="password" placeholder="请输入密码" id="password">
            </td>
        </tr>
        <!--Email-->
        <tr>
            <td class="td_left">
                <label for="email">Email</label>
            </td>
            <td class="td_right">
                <input type="email" name="email" placeholder="请输入Email" id="email">
            </td>
        </tr>
        <!--姓名-->
        <tr>
            <td class="td_left">
                <label for="name">姓名</label>
            </td>
            <td class="td_right">
                <input type="text" name="name" placeholder="请输入真实姓名" id="name">
            </td>
        </tr>
        <!--手机号-->
        <tr>
            <td class="td_left">
                <label for="tel">手机号</label>
            </td>
            <td class="td_right">
                <input type="number" name="tel" placeholder="请输入手机号" id="tel">
            </td>
        </tr>
        <!--性别-->
        <tr>
            <td class="td_left">
                <label>性别</label>
            </td>
            <td class="td_right">
                <input type="radio" name="gender"  value="male" checked>男
                <input type="radio" name="gender"  value="female" >女
            </td>
        </tr>
        <!--出生日期-->
        <tr>
            <td class="td_left">
                <label for="birthday">出生日期</label>
            </td>
            <td class="td_right">
                <input type="date" name="birthday" id="birthday">
            </td>
        </tr>
        <!--验证码-->
        <tr>
            <td class="td_left">
                <label for="checkcode">验证码</label>
            </td>
            <td class="td_right">
                <input type="text" name="checkcode" id="checkcode">
                <img src="img2/verify_code.jpg" class="img">
            </td>
        </tr>
        <!--注册-->
        <tr>
            <td colspan="2" align="center">
                <input type="submit" class="btu_sub" value="注册">
            </td>
        </tr>
    </table>

</form>
</div>

<div class="div3">
    <div class="div3_1">
        已有账号?<a class="div3_1_first" href="#">立即登录</a>
    </div>
</div>
</div>

</body>
</html>

运行截图:


html+css+javascript:

在这里我们来实现表单的校验功能,此处用到了事件监听机制,我们先来了解一下相关原理:

事件监听机制:
    * 概念:某些组件被执行了某些操作后,触发某些代码的执行。    
        * 事件:某些操作。如: 单击,双击,键盘按下了,鼠标移动了。
        * 事件源:组件。如: 按钮 文本输入框...
        * 监听器:代码。
        * 注册监听:将事件,事件源,监听器结合在一起。 当事件源上发生了某个事件,则触发执行某个监听器
        代码。

    用到的事件:
        1. onblur:离焦事件,用于判断鼠标是否离开当前输入框。
        2. onsubmit:表单事件,确认按钮被点击,用于判断表单是否点击提交按钮。
        
    实现步骤:
    1.给表单绑定onsubmit事件,监听器中判断每一个方法校验的结果。
        如果都为true,则监听器方法返回true,正常提交表单。
        如果有一个为false,则监听器方法返回false,阻止表单的提交。
    2.定义一些方法分别校验各个表单项。
    3.给各个表单绑定onblur事件。
    
    校验用户名等方法的实现步骤:
        1.获取用户名的值。
        2.定义用于判断的正则表达式。
        3.判断获取到的值是否符合正则表达式的规则。
        4.显示提示信息。
            如果符合规范,则显示√符号。
            如果不符合规范,则在输入框后面显示相关的提示信息。
            
    相关正则表达式的校验规则:
        用户名:6-18位,字母或数字    
        /^\w{6,18}$/
        密码:6-20 位,字母或数字    
        /^\w{6,20}$/            
        校验邮箱:数字或字母+@+小写字母或数字+ . +小写字母
        /^\w+@[a-z0-9]+\.[a-z]{2,4}$/
        校验姓名:汉字
        /^[\u2E80-\u9FFF]+$/
        校验手机号:以1开头的11为数字
        /^1[0-9]{10}$/

    关于正则表达式的定义规则,大家可以查询https://www.w3school.com.cn/js/js_regexp.asp,可以根据自己的
    实际情况做出相应的修改。
    
源码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>表单校验</title>

    <style>
        *{
            margin: 0px;
            padding: 0px;
            box-sizing: border-box;
        }

        body{
            background: url("img2/register_bg.png") no-repeat;
            width: 100%;
            height: 100%;
            padding-top: 25px;
        }

        .layout{
            width: 900px;
            height: 500px;
            background: white;
            border: 8px darkgrey solid;
            margin: auto;
        }

        .div1{
            /*border: 1px red solid;*/
            float: left;
            margin-left: 15px;
            margin-top: 20px;
        }

        .div1_1{
            color: gold;
            font-size:20px;
        }

        .div1_2{
            font-size: 20px;
            color: darkgrey;
        }

        .div2{
            /*border: 1px red solid;*/
            float: left;
            margin-left: 15px;
        }

        .td_left{
            text-align: right;
            height: 45px;
            color: darkgrey;
            width: 100px;
        }

        .td_right{
            padding-left: 50px;
        }

        #username,#password,#email,#name,#tel,#checkcode,#birthday{
            width: 251px;
            height: 32px;
            border-radius: 5px;
            border: darkgrey 1px solid;
            padding-left: 15px;
        }

        #checkcode{
            width: 120px;
        }

        .img{
            height: 32px;
            vertical-align: middle;
        }

        .btu_sub{
            width: 120px;
            height: 40px;
            border: gold 1px solid;
            background: gold;
        }

        .div3{
            /*border: 1px red solid;*/
            float: right;
            margin-top: 20px;
            margin-right: 15px;
        }

        .div3_1{
            font-size: 13px;
        }

        .div3_1_first{
            color: pink;
        }

        .error{
            color: red;
            font-size: 6px;
        }

    </style>

</head>
<body>

<div class="layout">
    <div class="div1">
        <div class="div1_1">
            新用户注册
        </div>
        <div class="div1_2">
            USER REGISTER
        </div>
    </div>

    <div class="div2">
        <form action="#" method="get" id="form">

            <table class="table">
                <!--用户名-->
                <tr>
                    <td class="td_left">
                        <label for="username">用户名</label>
                    </td>
                    <td class="td_right">
                        <input type="text" name="username" placeholder="请输入用户名" id="username">
                        <span id="s_username" class="error"></span>
                    </td>
                </tr>
                <!--密码-->
                <tr>
                    <td class="td_left">
                        <label for="password">密码</label>
                    </td>
                    <td class="td_right">
                        <input type="password" name="password" placeholder="请输入密码" id="password">
                        <span id="s_password" class="error"></span>
                    </td>
                </tr>
                <!--Email-->
                <tr>
                    <td class="td_left">
                        <label for="email">Email</label>
                    </td>
                    <td class="td_right">
                        <input type="email" name="email" placeholder="请输入Email" id="email">
                        <span id="s_email" class="error"></span>
                    </td>
                </tr>
                <!--姓名-->
                <tr>
                    <td class="td_left">
                        <label for="name">姓名</label>
                    </td>
                    <td class="td_right">
                        <input type="text" name="name" placeholder="请输入真实姓名" id="name">
                        <span id="s_name" class="error"></span>
                    </td>
                </tr>
                <!--手机号-->
                <tr>
                    <td class="td_left">
                        <label for="tel">手机号</label>
                    </td>
                    <td class="td_right">
                        <input type="number" name="tel" placeholder="请输入手机号" id="tel">
                        <span id="s_tel" class="error"></span>
                    </td>
                </tr>
                <!--性别-->
                <tr>
                    <td class="td_left">
                        <label>性别</label>
                    </td>
                    <td class="td_right">
                        <input type="radio" name="gender"  value="male" checked>男
                        <input type="radio" name="gender"  value="female" >女
                    </td>
                </tr>
                <!--出生日期-->
                <tr>
                    <td class="td_left">
                        <label for="birthday">出生日期</label>
                    </td>
                    <td class="td_right">
                        <input type="date" name="birthday" id="birthday">
                    </td>
                </tr>
                <!--验证码-->
                <tr>
                    <td class="td_left">
                        <label for="checkcode">验证码</label>
                    </td>
                    <td class="td_right">
                        <input type="text" name="checkcode" id="checkcode">
                        <img src="img2/verify_code.jpg" class="img">
                    </td>
                </tr>
                <!--注册-->
                <tr>
                    <td colspan="2" align="center">
                        <input type="submit" class="btu_sub" value="注册">
                    </td>
                </tr>
            </table>

        </form>
    </div>

    <div class="div3">
        <div class="div3_1">
            已有账号?<a class="div3_1_first" href="#">立即登录</a>
        </div>
    </div>
</div>


<script>

    //给表单绑定onsubmiit事件
    document.getElementById("form").onsubmit = function () {
        //判断每一个方法的校验结果
        return checkusername() && checkpassword() && checkemail()
            && checkname() && checktel();
    }

    //给每个表单绑定onblur事件
    document.getElementById("username").onblur = checkusername;
    document.getElementById("password").onblur = checkpassword;
    document.getElementById("email").onblur = checkemail;
    document.getElementById("name").onblur = checkname;
    document.getElementById("tel").onblur = checktel;

    //验证username
    function checkusername() {
        //获取用户名的值
        var username = document.getElementById("username").value;
        //定义正则表达式
        var reg = /^\w{6,18}$/;
        //判断是否符合正则表达式的规则
        var flag = reg.test(username);
        var s_username = document.getElementById("s_username");
        //显示提示信息
        if(flag){
            s_username.innerHTML = "<img src='img3/gou.png' width='40px' height='25px'>";
        }else{
            s_username.innerHTML = "用户名格式错误!";
        }
        return flag;
    }

    //验证password
    function checkpassword() {
        //获取用户名的值
        var password = document.getElementById("password").value;
        //定义正则表达式
        var reg = /^\w{6,20}$/;
        //判断是否符合正则表达式的规则
        var flag = reg.test(password);
        var s_password = document.getElementById("s_password");
        //显示提示信息
        if(flag){
            s_password.innerHTML = "<img src='img3/gou.png' width='40px' height='25px'>";
        }else{
            s_password.innerHTML = "密码格式错误!";
        }
        return flag;
    }

    //验证email
    function checkemail() {
        //获取用户名的值
        var email = document.getElementById("email").value;
        //定义正则表达式
        var reg = /^\w+@[a-z0-9]+\.[a-z]{2,4}$/;
        //判断是否符合正则表达式的规则
        var flag = reg.test(email);
        var s_email = document.getElementById("s_email");
        //显示提示信息
        if(flag){
            s_email.innerHTML = "<img src='img3/gou.png' width='40px' height='25px'>";
        }else{
            s_email.innerHTML = "Email格式错误!";
        }
        return flag;
    }

    //验证姓名
    function checkname() {
        //获取用户名的值
        var name = document.getElementById("name").value;
        //定义正则表达式
        var reg = /^[\u2E80-\u9FFF]+$/;
        //判断是否符合正则表达式的规则
        var flag = reg.test(name);
        var s_name = document.getElementById("s_name");
        //显示提示信息
        if(flag){
            s_name.innerHTML = "<img src='img3/gou.png' width='40px' height='25px'>";
        }else{
            s_name.innerHTML = "姓名不正确!";
        }
        return flag;
    }

    //验证手机号
    function checktel() {
        //获取用户名的值
        var tel = document.getElementById("tel").value;
        //定义正则表达式
        var reg = /^1[0-9]{10}$/;
        //判断是否符合正则表达式的规则
        var flag = reg.test(tel);
        var s_tel = document.getElementById("s_tel");
        //显示提示信息
        if(flag){
            s_tel.innerHTML = "<img src='img3/gou.png' width='40px' height='25px'>";
        }else{
            s_tel.innerHTML = "电话号码错误!";
        }
        return flag;
    }

    

</script>

</body>
</html>

运行截图:

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值