表单 用jquery做输入脱离焦点 进行正则验证
<!-- 账号登录块 -->
<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做输入脱离焦点 进行正则验证的更多相关文章
- 在表单提交之前做校验-利用jQuery的submit方法
点击表单中的提交按钮,默认就会提交表单,如果要在表单提交之前做一些校验,那么就可以用jQuery的submit方法. 也就是jQuery的submit的方法执行顺序,在表单的提交之前.用法如下: $( ...
- Web开发——HTML基础(HTML表单/下拉列表/多行输入)
参考: 参考:http://www.w3school.com.cn/html/html_forms.asp 目录: 1.<form> 元素 1.1 <input> 元素(输入属 ...
- 15 款优化表单的 jQuery 插件
网页上的表单提供给用户的一种交互的方式,用户输入数据,提交到服务器,等待后续的处理.这些表单在我们浏览的网页中随处可见,也容易被我们忽略. 比如,“联系我们”页面会提供一个表单给用户填写他们的信息和想 ...
- Form表单利用Jquery Validate验证以及ajax提交
#表单利用Jquery验证验证以及ajax提交 概述>详细讲解表单利用Jquery >验证验证以及ajax提交的过程,以及Validate的自定义提示语,非空判断,输入字段的远程ajax验 ...
- Jquery easyui 重置按钮,easyui 清空表单,Jquery easyui 重置表单
Jquery easyui 重置按钮,easyui 清空表单,Jquery easyui 重置表单 >>>>>>>>>>>>&g ...
- ios手机弹出层上表单的操作,收起键盘焦点错乱的问题
今天遇到了ios手机下 弹出层上form表单 当收起键盘后,焦点错乱,无法再操作的问题 解决办法 function device() { const u = navigator.userAgent; ...
- 让input表单输入框不记录输入过信息的方法
有过表单设计经验的朋友肯定知道,当我们在浏览器中输入表单信息的时候,往往input文本输入框会记录下之前提交表单的信息,以后每次只要双击input文本输入框就会出现之前输入的文本,这样有时会觉得比较方 ...
- spring mvc表单的展现、输入处理、校验的实现
之前已经实现了spring mvc的入门例子及如何处理带参数的请求Controller编写.本文主要记录: 1)重定向请求 2)处理路径中含有变量的请求 3)使用JSR-303进行校验 ① 首先,编写 ...
- Jquery validate验证表单时多个name相同的元素只验证第一个的问题
下面搜集了五种方法,主要还是前两个提供了解决方案,第三种需要修改jQuery源码: 修复jquery.validate插件中name属性相同(如name='a[]')时验证的bug 使用jquery. ...
随机推荐
- struts2类型转换1
概述 从一个 HTML 表单到一个 Action 对象, 类型转换是从字符串到非字符串. HTTP 没有 “类型” 的概念. 每一项表单输入只可能是一个字符串或一个字符串数组. 在服务器端, 必须把 ...
- Spring常见面试题及答案解析
.说一下spring中Bean的作用域 singleton: Spring IoC容器中只会存在一个共享的Bean实例,无论有多少个Bean引用它,始终指向同一对象.Singleton作用域是Spri ...
- php 连接mysql 主机 localhost,显示 No such file or directory
打开 php.ini文件,找到这1行 mysql.default_socket 然后将它修改为 mysql.default_socket=/path/to/mysql.sock /path/to/my ...
- vue cli3 vue.config配置
跳地址:https://cli.vuejs.org/zh/config/#publicpath
- leetcood学习笔记-104-二叉树的最大深度
题目描述: 第一次提交: class Solution(object): def maxDepth(self, root): """ :type root: TreeNo ...
- HashMap 介绍
基本介绍 1. 用于存储Key-Value键值对的集合(每一个键值对也叫做一个Entry)(无顺序). 2. 根据键的hashCode值存储数据,大多数情况下可以直接定位到它的值. 3. 键key为n ...
- Spring使用Redis
1.引入依赖 <dependency> <groupId>org.springframework.data</groupId> <artifactId> ...
- delphi 文件存取方法与文件管理组件
9.2 文件存取方法与文件管理组件 9.2.1 存取文件的类方法 Delphi在许多需要与文件打交道的类中定义了文件存取方法,使用这些方法可以非常方便地将类中的数据保存到文件中,或从文件中读取所需 ...
- 为什么要使用动态链接库(DLL)
为什么要使用动态链接库(DLL) 第一章 为什么要使用动态链接库(DLL) top 提起DLL您一定不会陌生,在Windows中有着大量的以DLL为后缀的文件,它们是保证Windows正常运行和维 ...
- hdu第九场多校
02:线段树两次扫描 #include<bits/stdc++.h> #include<vector> using namespace std; #define maxn 30 ...