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

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

代码演示:

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

image.png

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 演示图片:

image.png

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

image.png

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

image.png

image.png

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

<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 演示结果:

image.png

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

image.png

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


image.png

目录
相关文章
|
7天前
|
Web App开发 JavaScript 前端开发
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念,包括事件驱动、单线程模型和模块系统;探讨其安装配置、核心模块使用、实战应用如搭建 Web 服务器、文件操作及实时通信;分析项目结构与开发流程,讨论其优势与挑战,并通过案例展示 Node.js 在实际项目中的应用,旨在帮助开发者更好地掌握这一强大工具。
26 1
|
13天前
|
存储 安全 网络安全
云计算与网络安全:技术融合的双刃剑
【10月更文挑战第40天】本文将深入探讨云计算与网络安全之间的关系,揭示它们如何相互依赖又互相挑战。我们将从云计算的基本概念出发,逐步引入网络安全的重要性,并分析云服务在提供便利的同时可能带来的安全隐患。文章还将讨论信息安全的关键领域,如加密技术和身份验证机制,以及如何在云计算环境中加强这些安全措施。通过本文,读者将获得对云计算和网络安全复杂关系的深刻理解,并认识到在享受技术便利的同时,维护网络安全的重要性。
|
9天前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
21 5
|
10天前
|
监控 安全 网络安全
云计算与网络安全:探索云服务中的信息安全技术
【10月更文挑战第43天】本文将深入探讨云计算与网络安全的交汇点,重点分析云服务中的信息安全技术和策略。我们将从云计算的基础架构出发,逐步剖析网络安全的重要性,并介绍如何通过实施有效的安全措施来保护数据和应用程序。文章还将提供实用的代码示例,帮助读者更好地理解和应用这些安全技术。
26 4
|
13天前
|
存储 安全 网络安全
云计算与网络安全:云服务、网络安全、信息安全等技术领域
【10月更文挑战第40天】随着互联网技术的不断发展,云计算已经成为了现代社会中不可或缺的一部分。然而,云计算的普及也带来了一系列的安全问题。本文将探讨云计算与网络安全之间的关系,包括云服务、网络安全、信息安全等领域。我们将通过代码示例来展示如何保护云计算环境中的敏感信息和数据。最后,我们将总结云计算与网络安全之间的紧密联系,并展望未来的发展趋势。
|
14天前
|
云安全 安全 网络安全
云计算与网络安全:技术挑战与解决策略
【10月更文挑战第39天】随着云计算技术的飞速发展,网络安全问题也日益凸显。本文将探讨云计算环境下的网络安全挑战,并提出相应的解决策略。通过分析云服务模型、网络安全威胁以及信息安全技术的应用,我们将揭示如何构建一个安全的云计算环境。
|
14天前
|
存储 网络协议 安全
30 道初级网络工程师面试题,涵盖 OSI 模型、TCP/IP 协议栈、IP 地址、子网掩码、VLAN、STP、DHCP、DNS、防火墙、NAT、VPN 等基础知识和技术,帮助小白们充分准备面试,顺利踏入职场
本文精选了 30 道初级网络工程师面试题,涵盖 OSI 模型、TCP/IP 协议栈、IP 地址、子网掩码、VLAN、STP、DHCP、DNS、防火墙、NAT、VPN 等基础知识和技术,帮助小白们充分准备面试,顺利踏入职场。
47 2
|
15天前
|
云安全 安全 网络安全
云计算与网络安全:技术融合的未来之路
【10月更文挑战第38天】 在数字化浪潮中,云计算和网络安全成为支撑现代企业和个人数据安全的两大基石。本文将深入探讨云计算服务如何与网络安全技术相结合,保障信息安全,并分析面临的挑战及未来发展趋势。我们将通过实际案例,揭示云安全的最佳实践,为读者提供一条清晰的技术融合路径。
|
16天前
|
安全 网络安全 数据库
云计算与网络安全:技术融合的未来之路
【10月更文挑战第37天】本文将探讨云计算与网络安全的交汇点,揭示它们如何共同塑造信息安全的未来。我们将深入了解云服务的核心组件、网络安全的关键策略以及两者如何相互增强。通过分析当前的挑战和未来的趋势,本文旨在为读者提供一条清晰的路径,以理解并应对这一不断发展的技术领域。
|
17天前
|
网络协议 数据挖掘 5G
适用于金融和交易应用的低延迟网络:技术、架构与应用
适用于金融和交易应用的低延迟网络:技术、架构与应用
44 5