JavaScript---网络编程(12)--DHTML技术演示(5)-form表单验证技术(正则)

这里不进行很复杂的后台验证以及JavaScript的正则表达式,只是简单的介绍下这个技术,简单的后台接收与跳转,大概了解怎么验证的就可以。具体的技术,我后面还会继续写博客的。本人也还在学习中。

表单验证1-简单验证

进行简单的验证,用户名必须为abcd,密码长度必须大于等于6
然后根据用户输入的数据,在后面给出提示。

代码演示:

<html>
    <head>
        <title>DHTML技术演示---表单验证</title>
        <meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
        <script>
            function checkUserName(){
                //alert("aa");//测试这个失去焦点监听是否管用
                var oUserNameNode = document.getElementsByName("userName")[0];
                var name = oUserNameNode.value;//这个type="text"的value的值是方框内的字符
                //以后有后台时,“abcd”这个数据应该通过ajax技术向后台要
                //这里我们只是做简单的演示-就是填写的name必须是abcd
                if(name=="abcd"){
                    document.getElementById("userNameSpan").innerHTML="用户名正确".fontcolor("green");
                }else{
                    document.getElementById("userNameSpan").innerHTML="用户名错误".fontcolor("red");
                }
            }

            function checkPwd(){
                var oUserPwdNode = document.getElementById("pwd")[0];
                var pwd=oUserPwdNode.value;

                if(pwd.length>=6){
                    document.getElementById("userPwdSpan").innerHTML="密码格式符合要求".fontcolor("green");
                }else{
                    document.getElementById("userPwdSpan").innerHTML="密码长度必须大于等于6".fontcolor("red");
                }
            }

        </script>

    </head>

    <body>
        <form>
            <!--onblur 在对象失去输入焦点时触发。 -->
            用户名:<input type="text" name="userName" onblur="checkUserName()" />
            <span id="userNameSpan"></span>
            <br/>
            <br/>
            <!--为了演示清楚,密码这里也用type="text"了,其实应该用type="password"的-->
            密码:<input type="text" name="pwd" onblur="checkPwd()" />
            <span id="userPwdSpan"></span>
        </form>

    </body>

</html>

360浏览器8.1 演示结果:

用户名不符合规则:

密码不符合规则:

注册表单的验证2-正则表达式

代码演示:

<html>
    <head>
        <title>DHTML技术演示---注册表单的验证--js中使用正则表达式</title>
        <meta http-equiv="content-type" content="text/html; charset=UTF-8">
        <script type="text/javascript">
            function checkUserName(){
                var oUserNameNode = document.getElementsByName("userName")[0];
                var userName = oUserNameNode.value;
                //用正则检验
                var reg = new RegExp("[a-z]{4}", "i");//包含4个连续的字母就可以,注意"i"的双引号不能省略
                //i---表示忽略大小写
                //var regg =new RegExp("^[a-z]{4}$","i") ;//只含4个连续的字母,注意"i"中的双引号不能省略
                //^代表开始   $代表结束

                var oUserNameSpan = document.getElementById("userNameSpan");
                //alert(reg.test(userName));

                if (reg.test(userName)) {
                    oUserNameSpan.innerHTML = "用户名格式正确".fontcolor("green");
                }
                else {
                    oUserNameSpan.innerHTML = "用户名格式错误".fontcolor("red");
                }
            }
        </script>
    </head>

    <body>
        <!-- 演示JS中正则表达式的用法 -->
        <script type="text/javascript">
            //var reg = /^[0-9]{6}$/ ; //法一
            var reg = new RegExp("^[0-9]{6}$");//法二
            var str = "123456";
            var bRes = reg.test(str);
            //111使用正则表达式对象中的方法进行验证---只能用于判断是否匹配,功能类似于Java中的String类中的matches()方法
            //alert(bRes);//true

            //222使用String对象中的方法进行正则检验---功能更强大,类似于Java当中的Matcher工具
            var res = str.match(reg);//匹配的结果保存在res(是一个数组)中,如果没有匹配到则res为null。
            //alert(res);//123456
            //match方法返回的数组有三个属性:input、index和lastIndex。

            //一点细节---使用new RegExp()方式时,特殊字符要转义
            //var reg2 =/^\d{6}$/;  //"\"不需要转义
            var reg2= new RegExp("^\d{6}$");//※※※注意"\"要转义
            //▲▲▲上面那句是错误的,必须要写成:new RegExp("^\\d{6}$")
            //alert( reg2.test("123456") );
        </script>

        <form>
            <!--onblur 在对象失去输入焦点时触发。 -->
            用户名:<input type="text" name="userName" onblur="checkUserName()" />
            <span id="userNameSpan"></span>
        </form>

    </body>
</html>

360浏览器8.1 演示结果:

只需要包含连续4个字母就可以了。

注册表单的验证且控制提交–前端校验:

代码文件创建位置:

代码演示:

3form3.html

<html>
    <head>
        <title>DHTML技术演示---注册表单的验证且控制提交--前端校验</title>
        <meta http-equiv="content-type" content="text/html; charset=UTF-8">
        <script type="text/javascript">
            function checkUserName(){
                var oUserNameNode = document.getElementsByName("userName")[0];
                var userName = oUserNameNode.value;
                //用正则检验
                var reg = new RegExp("[a-z]{4}","i");//包含4个连续的字母就可以,注意"i"的双引号不能省略
                //i---表示忽略大小写
                //var regg =new RegExp("^[a-z]{4}$","i") ;//只含4个连续的字母,注意"i"中的双引号不能省略
                //^代表开始   $代表结束

                var oUserNameSpan = document.getElementById("userNameSpan");
                if(reg.test(userName)){
                    oUserNameSpan.innerHTML="用户名格式正确".fontcolor("green");
                    return true;
                }else{
                    oUserNameSpan.innerHTML="用户名格式错误".fontcolor("red");
                    return false;
                }
            }

            function checkPwd(){
                var oUserPwdNode = document.getElementsByName("pwd")[0];
                var pwd = oUserPwdNode.value;
                var reg2 = new RegExp("^[\\w\\d]{6,9}$");
                if(reg2.test(pwd)){
                    document.getElementById("userPwdSpan").innerHTML="密码格式符合要求".fontcolor("green");
                    return true;
                }else{
                    document.getElementById("userPwdSpan").innerHTML="密码长度必须是6-9位的数字字母或下划线".fontcolor("red");
                    return false;

                }
            }

            function checkUser(){
                if(checkUserName() && checkPwd() ){//如果还有其他项需要在提交前验证,直接把那个验证函数写这里就行
                    return true;
                }else{
                    return false;
                }

            }

        </script>

    </head>

    <body>
        <!--通过注册onsubmit事件响应来控制表单的提交,如果return false则不会提交,而return true则会提交。如果不注册onsubmit事件即是return true
        onsubmit 当表单将要被提交时触发。
        <form action="/myDhtmlProj/servlet/RegServlet" onsubmit="return true;">
        -->
        <form action="/myDhtmlProj/servlet/RegServlet" onsubmit="return checkUser();">
            用户名:<input type="text" name="userName" onblur="checkUserName()" />
            <span id="userNameSpan"></span>
            <!--为了演示清楚,密码这里也用type="text"了,其实应该用type="password"的-->
            密码:<input type="text" name="pwd" onblur="checkPwd()" />
            <span id="userPwdSpan"></span>
            <br/>
            <input type="submit" value="注册"/>
        </form>
        <hr/>

        <!--表单提交方式2---自己写个按钮来代替form自带的提交按钮-->
        <form id="userinfo" action="/dhtmlProj/servlet/RegServlet" >
            用户名:<input type="text" name="userName" onBlur="checkUserName2()"/>
            <span id="userNameSpan2"></span><br/>
            密码:<input type="text" name="pwd" onBlur="checkPwd2()"/>
            <span id="userPwdSpan2"></span>
            <br/>
        </form>
        <input type="button" value="注册" onclick="mySubmit()" />
        <script type="text/javascript">
            function mySubmit(){
                var oFormNode = document.getElementById("userinfo");
                if(checkUserName2()&&checkPwd2()){
                    oFormNode.submit();//submit 提交表单。
                }
            }

            function checkUserName2(){
                var oUserNameNode = document.getElementsByName("userName")[1];
                var userName = oUserNameNode.value;
                //用正则检验
                var reg = new RegExp("[a-z]{4}","i");//包含4个连续的字母就可以,注意"i"的双引号不能省略
                //i---表示忽略大小写
                //var regg =new RegExp("^[a-z]{4}$","i") ;//只含4个连续的字母,注意"i"中的双引号不能省略
                //^代表开始   $代表结束

                var oUserNameSpan = document.getElementById("userNameSpan2");
                if(reg.test(userName)){
                    oUserNameSpan.innerHTML="用户名格式正确".fontcolor("green");
                    return true;
                }else{
                    oUserNameSpan.innerHTML="用户名格式错误".fontcolor("red");
                    return false;
                }
            }

            function checkPwd2(){
                var oUserPwdNode = document.getElementsByName("pwd")[1];
                var pwd = oUserPwdNode.value;
                var reg2 = new RegExp("^[\\w\\d]{6,9}$");
                if(reg2.test(pwd)){
                    document.getElementById("userPwdSpan2").innerHTML="密码格式符合要求".fontcolor("green");
                    return true;
                }else{
                    document.getElementById("userPwdSpan2").innerHTML="密码长度必须是6-9位的数字字母或下划线".fontcolor("red");
                    return false;

                }
            }

        </script>

    </body>
</html>

show.jsp:

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
    <head>
        <title>这是注册后的显示页面</title>
    </head>

    <body>
        <%
            out.println(request.getAttribute("uName"));
            out.println(request.getAttribute("pwd"));
         %>
        <%
            for(int i=0;i<3;i++){
            //这个下面可以写html代码
        %>
            <div>欢迎</div>
        <%
            //这个上面可以写html代码
            }
        %>
    </body>
</html>

RegServlet.java
这个是new一个Servlet。
会自动给我们配好web.xml

package cn.hncu.user;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class RegServlet extends HttpServlet {
    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        doPost(request, response);
    }

    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        request.setCharacterEncoding("utf-8");//设置编码
        String name = request.getParameter("userName");//userName为提交过来的表单中的一个input的name属性
        String pwd = request.getParameter("pwd");
        //System.out.println(name);
        request.setAttribute("uName", "hncu---"+name);
        request.setAttribute("pwd", "pwd---"+pwd);

        request.getRequestDispatcher("/dhtml/6formsubmit/jsps/show.jsp").forward(request, response);
        //输出,导向另外的页面显示
    }

}

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
    xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
    http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <display-name></display-name>
  <servlet>
    <description>This is the description of my J2EE component</description>
    <display-name>This is the display name of my J2EE component</display-name>
    <servlet-name>RegServlet</servlet-name>
    <servlet-class>cn.hncu.user.RegServlet</servlet-class>
  </servlet>

  <servlet-mapping>
    <servlet-name>RegServlet</servlet-name>
    <url-pattern>/servlet/RegServlet</url-pattern>
  </servlet-mapping>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

360浏览器8.1 演示图片:

当格式都填写正确时,点注册按钮,自动跳转到另外的页面。

有一个格式错误时,点注册按钮不会有反应的。

注册表单的验证且控制提交–前端校验–最终版本:

代码演示:

<html>
    <head>
        <title>DHTML技术演示---注册表单的验证且控制提交--前端校验--最终版本</title>
        <meta http-equiv="content-type" content="text/html; charset=UTF-8"/>

        <script type="text/javascript">
            function check(name,reg,spanId,okInfo,errInfo){
                var value = document.getElementsByName(name)[0].value;
                //用正则检验
                var oSpanNode = document.getElementById(spanId);
                if(reg.test(value)){
                    oSpanNode.innerHTML=okInfo.fontcolor("green");
                    return true;
                }else{
                    oSpanNode.innerHTML=errInfo.fontcolor("red");
                    return false;
                }

            }

            function checkUserName(){
                var reg = new RegExp("[a-z]{4}","i");//包含4个连续的字母,注意"i"中的双引号不能省略
                return check("userName",reg,"userNameSpan","用户名格式正确","用户名格式错误");
            }

            function checkPwd(){
                var reg = new RegExp("^[\\w\\d]{6,9}$");
                return check("pwd",reg,"userPwdSpan","密码格式符合要求","密码长度必须是6-9位的数字字母或下划线");
            }

            function checkPwd2(){
                var flag;
                var pwd = document.getElementsByName("pwd")[0].value;
                var pwd2 = document.getElementsByName("pwd2")[0].value;
                var oSpanNode = document.getElementById("userPwd2Span");
                if(pwd==pwd2){
                    oSpanNode.innerHTML="两次密码一致".fontcolor("green");
                    flag = true;
                }else{
                    oSpanNode.innerHTML="两次密码不一致".fontcolor("red");
                    flag = false;
                }
                return flag;
            }

            function checkMail(){
                var reg = /^\w+@\w+(\.\w+)+$/i;
                return check("mail",reg,"userMailSpan","邮箱格式正确","邮箱格式不正确");
            }

            function checkUser(){//控制表单的提交
                if(checkUserName() && checkPwd() && checkPwd2() && checkMail() ){
                    return true;
                }else{
                    return false;
                }
            }

        </script>

    </head>

    <body>
        <form action="/myDhtmlProj/servlet/RegServlet" onsubmit="return checkUser();">
            用户名:<input type="text" name="userName" onblur="checkUserName()" />
            <span id="userNameSpan"></span>
            <br/>
            输入密码:<input type="text" name="pwd" onblur="checkPwd()" />
            <span id="userPwdSpan"></span>
            <br/>
            确认密码:<input type="text" name="pwd2" onBlur="checkPwd2()"/>
            <span id="userPwd2Span"></span>
            <br/>
            邮件地址:<input type="text" name="mail" onblur="checkMail()" />
            <span id="userMailSpan"></span>
            <br/>
            <input type="submit" value="注册">
        </form>

    </body>
</html>

360浏览器8.1 演示结果:

只有全部格式填写正确后再点注册按钮才会有响应。

全部格式填写正确后,点注册按钮后的页面,其实就是跳到show.jsp页面了。(自己可以随便定位到哪的)

时间: 2024-09-27 09:07:03

JavaScript---网络编程(12)--DHTML技术演示(5)-form表单验证技术(正则)的相关文章

javascript 表单验证常见正则_javascript技巧

复制代码 代码如下: /* 用途:校验ip地址的格式 输入:strIP:ip地址 返回:如果通过验证返回true,否则返回false: */ function isIP(strIP) { if (isNull(strIP)) return false; var re = /^(\d+)\.(\d+)\.(\d+)\.(\d+)$/g //匹配IP地址的正则表达式 if (re.test(strIP)) { if (RegExp.$1 < 256 && RegExp.$2 < 2

详细解读AngularJS中的表单验证编程

  这篇文章主要介绍了详细解读AngularJS中的表单验证编程,AngularJS是一个非常热门的JavaScript库,需要的朋友可以参考下 需求 Name 必填 Username 非必填,最小长度3,最大长度8 Email 非必填,但必须是合法的email 验证未通过的表单不能提交 显示一个必填或者非法email格式的错误信息 如果正确提交就弹出一个祝贺信息 现在知道我们的目标了吧,让我们一起来构建这个东西吧. Angular 的表单属性 $valid, $invalid, $pristi

JavaScript中Form表单技术汇总(推荐)_javascript技巧

这里不进行很复杂的后台验证以及JavaScript的正则表达式,只是简单的介绍下这个技术,简单的后台接收与跳转,大概了解怎么验证的就可以.具体的技术,我后面还会继续写博客的.本人也还在学习中. 表单验证1-简单验证 进行简单的验证,用户名必须为abcd,密码长度必须大于等于6 然后根据用户输入的数据,在后面给出提示. 代码演示: <html> <head> <title>DHTML技术演示---表单验证</title> <meta http-equiv

javascript实现通用表单验证函数

javascript|表单验证|函数 不管是动态网站,还是其它B/S结构的系统,都离不开表单表单做为客户端向服务器提交数据的载体担当相当重要的角色.这就引出了一个问题,提交的数据合法吗?摆在我们面前的问题就是验证这些数据保证所提交的数据是合法的.所以,我们写了一个大堆的验证函数.当我们开始新的一个项目的开发时,我们又得写一大堆的验证函数,然后再调试这一大堆的函数... 本文将介绍一种方法来提高我的代码的可重用性,提高我们的开发效率. 个人以为表单的验证应该包含两部分:第一,判断用户输入的数据是否

ASP动态生成的javascript表单验证代码

javascript|表单验证|动态 以网上down了一个ASP动态生成Form验证javascript的代码,自己扩容了一下.作者的大名我给忘了,不过我记得清楚,从第一条至第九条的代码都是该作者的原创.至于九至第十五条却是本人自己加的哦.而且由于本人水平有限,从第九条至第十五条不见得会条条生效啊?呵呵,其实把它贴在这里没有什么必要的,因为这点小会伎俩谁都会用的,我把它的作用定位为:开发时找不到该函数时到这里拷贝一下就可以了.呵,因为我即没有刻录机也没有移动硬盘.实在是没有办法把这些代码随身携带

实用代码分析:JavaScript通用表单验证函数

javascript|表单验证|函数 Check.js   JS函数文件/////////////////////////////////////////////////////////////////////////////////* *--------------- 客户端表单通用验证CheckForm(oForm) ----------------- * 功能:通用验证所有的表单元素. * 使用: *    <form name="form1" > *    <

详解JavaScript中的表单验证

       这篇文章主要介绍了JavaScript中的表单验证,是JS在前端和服务器端通信部分相关的重要知识,需要的朋友可以参考下             表单验证用于发生在服务器,客户端已经输入所有必要的数据,然后按下提交按钮之后.如果一些已被输入的客户端的数据的已在错误形式或者被简单地丢失,则服务器将必须的所有数据发送回客户端,并请求的形式以正确的信息重新提交.这是一个漫长的过程,会增加服务器负担.         JavaScript中,提供了一种方法将其发送到web服务器之前验证客户端

JavaScript实现仿网易通行证表单验证

  这篇文章主要介绍了JavaScript实现仿网易通行证表单验证,十分的实用,有需要的小伙伴可以参考下. 介绍一下表单验证,不错哦: 如图 CSS代码 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60

JavaScript获取按钮所在form表单id的方法

 本文实例讲述了JavaScript获取按钮所在form表单id的方法.分享给大家供大家参考.具体如下: 这里使用javascript获取form表单按钮的id,可以通过下面的JS代码获取. 1 2 3 4 5 6 7 8 9 10 11 12 13 <!DOCTYPE html> <html> <body> <h1>www.sharejs.com</h1> <form id="form1"> <button