1. 注册

 $(function() {
     /*
      * 1. 得到所有的错误信息,循环遍历之。调用一个方法来确定是否显示错误信息!
      */
     $(".errorClass").each(function() {
         showError($(this));//遍历每个元素,使用每个元素来调用showError方法
     });

     /*
      * 2. 切换注册按钮的图片
      */
     $("#submitBtn").hover(
         function() {
             $("#submitBtn").attr("src", "/goods/images/regist2.jpg");
         },
         function() {
             $("#submitBtn").attr("src", "/goods/images/regist1.jpg");
         }
     );

     /*
      * 3. 输入框得到焦点隐藏错误信息
      */
     $(".inputClass").focus(function() {
         var labelId = $(this).attr("id") + "Error";//通过输入框找到对应的label的id
         $("#" + labelId).text("");//把label的内容清空!
         showError($("#" + labelId));//隐藏没有信息的label
     });

     /*
      * 4. 输入框失去焦点进行校验
      */
     $(".inputClass").blur(function() {
         var id = $(this).attr("id");//获取当前输入框的id
         var funName = "validate" + id.substring(0,1).toUpperCase() + id.substring(1) + "()";//得到对应的校验函数名
         eval(funName);//执行函数调用
     });

     /*
      * 5. 表单提交时进行校验
      */
     $("#registForm").submit(function() {
         var bool = true;//表示校验通过
         if(!validateLoginname()) {
             bool = false;
         }
         if(!validateLoginpass()) {
             bool = false;
         }
         if(!validateReloginpass()) {
             bool = false;
         }
         if(!validateEmail()) {
             bool = false;
         }
         if(!validateVerifyCode()) {
             bool = false;
         }

         return bool;
     });
 });

 /*
  * 登录名校验方法
  */
 function validateLoginname() {
     var id = "loginname";
     var value = $("#" + id).val();//获取输入框内容
     /*
      * 1. 非空校验
      */
     if(!value) {
         /*
          * 获取对应的label
          * 添加错误信息
          * 显示label
          */
         $("#" + id + "Error").text("用户名不能为空!");
         showError($("#" + id + "Error"));
         return false;
     }
     /*
      * 2. 长度校验
      */
     if(value.length < 3 || value.length > 20) {
         /*
          * 获取对应的label
          * 添加错误信息
          * 显示label
          */
         $("#" + id + "Error").text("用户名长度必须在3 ~ 20之间!");
         showError($("#" + id + "Error"));
         false;
     }
     /*
      * 3. 是否注册校验
      */
     $.ajax({
         url:"/goods/UserServlet",//要请求的servlet
         data:{method:"ajaxValidateLoginname", loginname:value},//给服务器的参数
         type:"POST",
         dataType:"json",
         async:false,//是否异步请求,如果是异步,那么不会等服务器返回,我们这个函数就向下运行了。
         cache:false,
         success:function(result) {
             if(!result) {//如果校验失败
                 $("#" + id + "Error").text("用户名已被注册!");
                 showError($("#" + id + "Error"));
                 return false;
             }
         }
     });
     return true;
 }

 /*
  * 登录密码校验方法
  */
 function validateLoginpass() {
     var id = "loginpass";
     var value = $("#" + id).val();//获取输入框内容
     /*
      * 1. 非空校验
      */
     if(!value) {
         /*
          * 获取对应的label
          * 添加错误信息
          * 显示label
          */
         $("#" + id + "Error").text("密码不能为空!");
         showError($("#" + id + "Error"));
         return false;
     }
     /*
      * 2. 长度校验
      */
     if(value.length < 3 || value.length > 20) {
         /*
          * 获取对应的label
          * 添加错误信息
          * 显示label
          */
         $("#" + id + "Error").text("密码长度必须在3 ~ 20之间!");
         showError($("#" + id + "Error"));
         false;
     }
     return true;
 }

 /*
  * 确认密码校验方法
  */
 function validateReloginpass() {
     var id = "reloginpass";
     var value = $("#" + id).val();//获取输入框内容
     /*
      * 1. 非空校验
      */
     if(!value) {
         /*
          * 获取对应的label
          * 添加错误信息
          * 显示label
          */
         $("#" + id + "Error").text("确认密码不能为空!");
         showError($("#" + id + "Error"));
         return false;
     }
     /*
      * 2. 两次输入是否一致校验
      */
     if(value != $("#loginpass").val()) {
         /*
          * 获取对应的label
          * 添加错误信息
          * 显示label
          */
         $("#" + id + "Error").text("两次输入不一致!");
         showError($("#" + id + "Error"));
         false;
     }
     return true;
 }

 /*
  * Email校验方法
  */
 function validateEmail() {
     var id = "email";
     var value = $("#" + id).val();//获取输入框内容
     /*
      * 1. 非空校验
      */
     if(!value) {
         /*
          * 获取对应的label
          * 添加错误信息
          * 显示label
          */
         $("#" + id + "Error").text("Email不能为空!");
         showError($("#" + id + "Error"));
         return false;
     }
     /*
      * 2. Email格式校验
      */
     if(!/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$/.test(value)) {
         /*
          * 获取对应的label
          * 添加错误信息
          * 显示label
          */
         $("#" + id + "Error").text("错误的Email格式!");
         showError($("#" + id + "Error"));
         false;
     }
     /*
      * 3. 是否注册校验
      */
     $.ajax({
         url:"/goods/UserServlet",//要请求的servlet
         data:{method:"ajaxValidateEmail", email:value},//给服务器的参数
         type:"POST",
         dataType:"json",
         async:false,//是否异步请求,如果是异步,那么不会等服务器返回,我们这个函数就向下运行了。
         cache:false,
         success:function(result) {
             if(!result) {//如果校验失败
                 $("#" + id + "Error").text("Email已被注册!");
                 showError($("#" + id + "Error"));
                 return false;
             }
         }
     });
     return true;
 }

 /*
  * 验证码校验方法
  */
 function validateVerifyCode() {
     var id = "verifyCode";
     var value = $("#" + id).val();//获取输入框内容
     /*
      * 1. 非空校验
      */
     if(!value) {
         /*
          * 获取对应的label
          * 添加错误信息
          * 显示label
          */
         $("#" + id + "Error").text("验证码不能为空!");
         showError($("#" + id + "Error"));
         return false;
     }
     /*
      * 2. 长度校验
      */
     if(value.length != 4) {
         /*
          * 获取对应的label
          * 添加错误信息
          * 显示label
          */
         $("#" + id + "Error").text("错误的验证码!");
         showError($("#" + id + "Error"));
         false;
     }
     /*
      * 3. 是否正确
      */
     $.ajax({
         url:"/goods/UserServlet",//要请求的servlet
         data:{method:"ajaxValidateVerifyCode", verifyCode:value},//给服务器的参数
         type:"POST",
         dataType:"json",
         async:false,//是否异步请求,如果是异步,那么不会等服务器返回,我们这个函数就向下运行了。
         cache:false,
         success:function(result) {
             if(!result) {//如果校验失败
                 $("#" + id + "Error").text("验证码错误!");
                 showError($("#" + id + "Error"));
                 return false;
             }
         }
     });
     return true;
 }

 /*
  * 判断当前元素是否存在内容,如果存在显示,不页面不显示!
  */
 function showError(ele) {
     var text = ele.text();//获取元素的内容
     if(!text) {//如果没有内容
         ele.css("display", "none");//隐藏元素
     } else {//如果有内容
         ele.css("display", "");//显示元素
     }
 }

 /*
  * 换一张验证码
  */
 function _hyz() {
     /*
      * 1. 获取<img>元素
      * 2. 重新设置它的src
      * 3. 使用毫秒来添加参数
      */
     $("#imgVerifyCode").attr("src", "/goods/VerifyCodeServlet?a=" + new Date().getTime());
 }

regist.js

网上图书商城1--User模块的更多相关文章

  1. 基于SSH的网上图书商城-JavaWeb项目-有源码

    开发工具:Myeclipse/Eclipse + MySQL + Tomcat 项目简介: 技术:Java:JSP:JDBC,struts2,spring,hibernate数据库: mysqlweb ...

  2. JavaWeb网上图书商城完整项目--day02-4.regist页面提交表单时对所有输入框进行校验

    1.现在我们要将table表中的输入的参数全部提交到后台进行校验,我们提交我们是按照表单的形式提交,所以我们首先需要在table表外面添加一个表单 <%@ page language=" ...

  3. JavaWeb网上图书商城完整项目--24.注册页面的css样式实现

    现在框架已经做好了,即下来我们要对页面进行装饰了,第一步给每一个元素添加id 1.最外面的div添加id为divMain 2.第二个div添加id为divTitle,里面的span对应的id为span ...

  4. 网上图书商城项目学习笔记-011Book模块查询(分页)

    一.流程分析 1.图书模块 2.分布分析 二.代码 1.view层 1)list.jsp <%@ page language="java" import="java ...

  5. JavaWeb网上图书商城完整项目--day03-1.图书模块功能介绍及相关类创建

    1 前两天我们学习了user用户模块和图书的分类模块,接下来我们学习图书模块 图书模块的功能主要是下面的功能: 2 接下来我们创建对应的包 我们来看看对应的数据库表t_book CREATE TABL ...

  6. 网上图书商城项目学习笔记-012BOOK模块查询2

    一.分析 > 按图名查询(模糊)(分页)> 按作者查询(分页)> 按出版社查询(分页)> 按id查询> 多条件组合查询(分页) 二.代码 1.view层 (1)gj.js ...

  7. JavaWeb网上图书商城完整项目--21.用户模块各层相关类的创建

    1.现在要为user用户模块创建类 用户模块功能包括:注册.激活.登录.退出.修改密码. User类对照着t_user表来写即可.我们要保证User类的属性名称与t_user表的列名称完全相同. 我们 ...

  8. JavaWeb网上图书商城完整项目--day02-24.分类模块的相关类创建

    所谓的分类模块:就是显示所有的分类的功能,显示所有的分类在left.jsp页面中 这就是显示所有的分类: 要实现上面的,我们首先创建一个分类模块,该模块需要实现下面的功能 我们先创建上面的java包 ...

  9. 网上图书商城3--Book模块

    小技巧一:分页 ①PageBean<Book> findByCriteria(List<Expression> exprList, int pc)  --- 通用的查询方法(p ...

  10. 网上图书商城2--Category模块

    sql CREATE TABLE `t_category` ( `cid` char(32) NOT NULL, `cname` varchar(50) DEFAULT NULL, `pid` cha ...

随机推荐

  1. PHP_01之PHP概述、数据、语法

    1.定义:PHP Hypertext Preprocessor,超文本预处理器,服务器端脚本语言:2.环境:WAMP:Window+Apache+PHP+MySQL: LAMP:Linux+Apach ...

  2. HTML网页内容转换成字符串(删除从指定字符串到指定字符串)

    背景: 最近遇到个小需求就是将下面字符串去掉无用字符串 <br><br>"你爷爷也喜欢吃鱼嘛."<br><br>我笑了起来,&quo ...

  3. Android入门(四)UI-创建自定义控件

    原文链接:http://www.orlion.ga/441/ 一.引入布局 iphone应用顶部会有一个标题栏,我们可以模仿着做一个,但是如果我们的程序中很多个活动都需要这样的标题栏,如果 每一个活动 ...

  4. Zookeeper-Zookeeper启动过程

    在上一篇,我们了解了zookeeper最基本的配置,也从中了解一些配置的作用,那么这篇文章中,我们将介绍Zookeeper的启动过程,我们在了解启动过程的时候还要回过头看看上一篇中各个配置参数在启动时 ...

  5. 浅谈AngularJS中的$parse和$eval

    AngularJS的初学者常常会对$parse和$eval两个内建服务感到有些困惑,今天我们就来说说AngularJS中的$parse和$eval. 总的来说,$parse和$eval都是作用于Ang ...

  6. Cocos2d-x 3.2 学习笔记(七)Scene And Transition

    Scene 场景. 是一个抽象的概念,仅被用作Node(节点)的一个子类. Scene (场景)和Node(节点)几乎相同,不同的是Scene的默认锚点在屏幕的中心. 关于场景,不得不提的是场景之间的 ...

  7. 必应词典3.2去广告备忘笔记(转摘于roustar31)

    下载安装包后,沙盘运行,得到本体BingDict_Setup.msi文件,起作用的就是这个,其他的无视了.使用命令行参数:msiexec /a "d:\BingDict_Setup.msi& ...

  8. ISTool5.3.1汉化版使用教程

    ISTool是帮助你创建由Jordan Russell制作的Inno Setup编译器脚本的工具.Inno是一个出色的编译器,即使对于某些专业的安装制作程序,它唯一的缺点就是它的脚本必须手动编写. 这 ...

  9. [转载]基于TFS实践敏捷-工作项跟踪

    工作项跟踪(1) 可跟踪性是软件过程的重要能力,TFS主要是以工作项来实现过程的可跟踪性.曾有人问:"你们实际项目里的工作项是怎么样的?能不能让我们看看?"我也一直很好奇别的公司T ...

  10. node.js + mongodb 做项目的详解(一)

    想写博客很长时间了,因为一直身患懒癌,所以一直拖到了现在.markdown的语法也是刚刚学,试验一下效果好了不说了,直接上干货了.----------------------------------- ...