<!-- 账号登录块 -->
       <form class="form1" action="" method="get" onsubmit="return sub();">
        <label></label>
        <input class="user-name user" type="text" placeholder="邮箱/手机号码/小米ID">
        <input class="user-name mima" type="password" name="" id="" value="" placeholder="密码">
        <div class="clear"></div>
        <p class="alert at1">
         <span>!</span>
         账号格式不正确
        </p>
        <p class="alert at2">
         <span>!</span>
         密码格式不正确
        </p>
        <input class="loading" type="submit" id="" name="" value="登录" />
       </form>
       <!-- 手机短信登录注册快 -->
       <form class="form2" action="" method="get">
        <label class="lb1">+86</label>
        <input class="user-name phone" type="text" placeholder="手机号码">
        <input class="user-name yzm" type="password" name="" id="" value="" placeholder="短信验证码"><label class="lb2">获取验证码</label>
        <div class="clear"></div>
        <p class="alert at3">
         <span>!</span>
         手机号格式不正确
        </p>
        <p class="alert at4">
         <span>!</span>
         短信验证码不正确
        </p>
        <input class="loading" type="submit" id="" name="" value="立即登录/注册" />
       </form>

// 用户名验证
   $(".user").focus(function(){
      $(".user").css("background-color","#FFFFCC");
    });
   $(".alert").hide();
   
    $(".user").blur(function(){
   var n = $(".user").eq(0).val();
   
   if(!isMobil(n)){
    if(!isMail(n))
    {
     if (!isTrueName(n)) {
      $(".at1").show();
      $(".user").eq(0).css("border-color","red");
     } else{
      $(".alert").hide();
      $(".user").eq(0).css("border-color"," #ABADB3");
     }
    }else{
     $(".alert").hide();
     $(".user").eq(0).css("border-color"," #ABADB3");
    }
   }else{
     $(".alert").hide();
     $(".user").eq(0).css("border-color"," #ABADB3");
    }
    });
  
  // 密码验证
  $(".mima").focus(function(){
     $(".mima").css("background-color","#FFFFCC");
   });
     $(".alert").hide();
     
   $(".mima").blur(function(){
     var m = $(".mima").eq(0).val();
     if(!isPasswd(m)){
      $(".at2").show();
      $(".mima").eq(0).css("border-color","red");
     }else{
      $(".alert").hide();
      $(".mima").eq(0).css("border-color"," #ABADB3");
     }
      
   });
   //手机格式验证
  $(".phone").focus(function(){
     $(".phone").css("background-color","#FFFFCC");
   });
     $(".alert").hide();
     
   $(".phone").blur(function(){
     var p = $(".phone").eq(0).val();
     if(!isMobil(p)){
        $(".at3").show();
        $(".phone").eq(0).css("border-color","red");
     }else{
       $(".alert").hide();
       $(".phone").eq(0).css("border-color"," #ABADB3");
      }
   });
  //验证码
  $(".yzm").focus(function(){
     $(".yzm").css("background-color","#FFFFCC");
   });
     $(".alert").hide();
     
   $(".yzm").blur(function(){
     var y = $(".yzm").eq(0).val();
     if(!isyzm(y)){
        $(".at4").show();
        $(".yzm").eq(0).css("border-color","red");
     }else{
       $(".alert").hide();
       $(".yzm").eq(0).css("border-color"," #ABADB3");
      }
   });
  });
 
 验证函数
 /* 校验手机号 */
 function isMobil(s)
 {
 var patrn=/^1(3|4|5|7|8)\d{9}$/;
 if (!patrn.exec(s)) {return false}
 else{return true}
 }
 /*邮箱验证*/
 function isMail(s)
 {
 var patrn=/^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+$/;
 if (!patrn.exec(s)) {return false}
 else{return true}
 }
 
 /* 校验用户名 */
 function isTrueName(s)
 {
 var patrn=/^[a-zA-Z]{4,8}$/;
 if (!patrn.exec(s)) {return false}
 else{return true}
 }
 
 //校验密码:只能输入6-20个字母、数字、下划线
 function isPasswd(s)
 {
 var patrn=/^(\w){6,20}$/;
 if (!patrn.exec(s)) {return false}
 else{return true}
 }
 
 /* 校验手机号 */
 function isyzm(s)
 {
 var patrn=/^\d{5}$/;
 if (!patrn.exec(s)) {return false}
 else{return true}
 }

表单 用jquery做输入脱离焦点 进行正则验证的更多相关文章

  1. 在表单提交之前做校验-利用jQuery的submit方法

    点击表单中的提交按钮,默认就会提交表单,如果要在表单提交之前做一些校验,那么就可以用jQuery的submit方法. 也就是jQuery的submit的方法执行顺序,在表单的提交之前.用法如下: $( ...

  2. Web开发——HTML基础(HTML表单/下拉列表/多行输入)

    参考: 参考:http://www.w3school.com.cn/html/html_forms.asp 目录: 1.<form> 元素 1.1 <input> 元素(输入属 ...

  3. 15 款优化表单的 jQuery 插件

    网页上的表单提供给用户的一种交互的方式,用户输入数据,提交到服务器,等待后续的处理.这些表单在我们浏览的网页中随处可见,也容易被我们忽略. 比如,“联系我们”页面会提供一个表单给用户填写他们的信息和想 ...

  4. Form表单利用Jquery Validate验证以及ajax提交

    #表单利用Jquery验证验证以及ajax提交 概述>详细讲解表单利用Jquery >验证验证以及ajax提交的过程,以及Validate的自定义提示语,非空判断,输入字段的远程ajax验 ...

  5. Jquery easyui 重置按钮,easyui 清空表单,Jquery easyui 重置表单

    Jquery easyui 重置按钮,easyui 清空表单,Jquery easyui 重置表单 >>>>>>>>>>>>&g ...

  6. ios手机弹出层上表单的操作,收起键盘焦点错乱的问题

    今天遇到了ios手机下 弹出层上form表单 当收起键盘后,焦点错乱,无法再操作的问题 解决办法 function device() { const u = navigator.userAgent; ...

  7. 让input表单输入框不记录输入过信息的方法

    有过表单设计经验的朋友肯定知道,当我们在浏览器中输入表单信息的时候,往往input文本输入框会记录下之前提交表单的信息,以后每次只要双击input文本输入框就会出现之前输入的文本,这样有时会觉得比较方 ...

  8. spring mvc表单的展现、输入处理、校验的实现

    之前已经实现了spring mvc的入门例子及如何处理带参数的请求Controller编写.本文主要记录: 1)重定向请求 2)处理路径中含有变量的请求 3)使用JSR-303进行校验 ① 首先,编写 ...

  9. Jquery validate验证表单时多个name相同的元素只验证第一个的问题

    下面搜集了五种方法,主要还是前两个提供了解决方案,第三种需要修改jQuery源码: 修复jquery.validate插件中name属性相同(如name='a[]')时验证的bug 使用jquery. ...

随机推荐

  1. SingalR 构建 推送服务器初探

    项目需要用到推送,于是重新研究了下推送框架,最好能够独立成一个服务,与业务无关的服务,可以给所有的项目通用.找了好久最终决定用SinglR 框架. Signal 是微软支持的一个运行在 Dot NET ...

  2. 轻量级的惰性控件——ViewStub

    在开发过程中,有时候,需要这样一种控件,正常情况下不可见,不占用任何布局空间,只在某种特定情况下显示,这种情况下,我们使用一个普通的View,利用设置setVisibility(View.GONE)自 ...

  3. Object相关方法

    const object1 = { a: 'somestring', b: 42, c: false }; console.log(Object.values(object1)); // expect ...

  4. 《代码大全2》读书笔记 Week4

    <代码大全2>第8章:防御式编程 防御式编程的主要思想是子程序应该不因为非法的输入值被破坏,就好比开车时的防御式驾驶:你无法预估其他司机将会做什么,但你要采取措施保证当他人做出危险动作时自 ...

  5. 微信小程序开发系列之Hello World

    第一步:注册 在微信公众平台官网首页,点击注册.(相关文档可以找到,这里不再累述,望见谅.) 微信小程序注册成功后界面 第二步:编辑器.开发工具 我们假定你已经申请注册好微信小程序了,我们选定一个代码 ...

  6. 通过actionlib控制jaco机械臂

    为了安全,先写一个简单控制三个手指的程序: 根据驱动包内kinova_fingers_action.cpp服务器写客户端程序 #include <ros/ros.h> #include & ...

  7. P1487 失落的成绩单

    P1487 失落的成绩单a[i]=a[i-2]-2.0*a[i-1]+2.0*d;a[2]越大,a[3]越小a[3]越大,a[4]越小所以a[2]越大,a[4]越大,a[3]越小就有了单调性,分奇偶进 ...

  8. parseFloat 和 Number isNaN 转换

    parseFloat(true) // NaN Number( parseFloat(null) // NaN Number( parseFloat('') // NaN Number('') par ...

  9. 整理delphi及整理原则

    回看delphi使用的人也不多,但一直觉得这门语言挺好的,所以一直在用,在很多方面也给了很多帮助和启示 加上delphi的学习文件也确实比较少,故收集起来也不容易.今日,重新整理一下delphi ,一 ...

  10. 【CSS】float

    写在前面的话: 由于CSS内容比较多,小菜没有精力从头到尾讲一遍,只能有针对性的讲解. 如果读者理解CSS盒子模型,但对于浮动不理解,那么这篇文章可以帮助你. 小菜水平有限,本文仅仅是入门教程,不当之 ...