详解表单验证正则表达式实例(推荐)

验证:!reg.test(value)

邮箱:

代码如下:

reg = /^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/i;

不包含中文:

代码如下:

reg = /.*[\u4e00-\u9fa5]+.*$/i;

身份证号:

// 验证身份证号码
var city = {11:'北京',12:'天津',13:'河北',14:'山西',15:'内蒙古',21:'辽宁',22:'吉林',23:'黑龙江 ',31:'上海',32:'江苏',33:'浙江',34:'安徽',35:'福建',36:'江西',37:'山东',41:'河南',42:'湖北 ',43:'湖南',44:'广东',45:'广西',46:'海南',50:'重庆',51:'四川',52:'贵州',53:'云南',54:'西藏 ',61:'陕西',62:'甘肃',63:'青海',64:'宁夏',65:'新疆',71:'台湾',81:'香港',82:'澳门',91:'国外 '};
function check_idcard(n)
{
var im = 0;
var info, i, bd;
if(n.length != 18)
{
return false;
}
n = n.replace(/x$/i,"a");
if(city[parseInt(n.substr(0,2))] == null)
{
return false;
}
bd = n.substr(6,4)+"-"+Number(n.substr(10,2))+"-"+Number(n.substr(12,2));
var d = new Date(bd.replace(/-/g,"/"))
if(bd != (d.getFullYear()+"-"+ (d.getMonth()+1) + "-" + d.getDate()))
{
return false;
}
for(i = 17; i >= 0; i--)
{
im += (Math.pow(2,i) % 11) * parseInt(n.charAt(17 - i),11)
}
if(im % 11 != 1)
{
return false;
}
return true;
} 

密码强度检测:

function ops_pwd_set(obj)
{
var pwd = obj;
if(typeof obj.value != 'undefined')
pwd = obj.value;
if(pwd == '')
return false;
var len = pwd.length;
if(pwd == '')
{
ops_show("密码不能为空",true);
return false;
}
//中文
if(/[\u4e00-\u9fa5]+/.test(pwd)){
ops_show("密码不能含有中文",true);
return false;
}
//空白
var tmppwd = pwd.replace(/\s+/g,"");
if(tmppwd != pwd){
ops_show("密码不能含有空白字符",true);
return false;
}
//长度
if( len < 6 || len > 20){
ops_show("密码长度需在6-20位之间",true);
return false;
}
//正则表达式
var is_all_num = /^\d+$/.test(pwd) ;
var have_num = /\d/.test(pwd) ;
var is_all_abc = /^[a-zA-Z]+$/.test(pwd) ;
var have_abc = /[a-zA-Z]/.test(pwd) ;
var have_strong = /[^a-zA-Z0-9]/.test(pwd) ;
var is_very_strong = pwd.split(/[^a-zA-Z_0-9]/).length > 2 ;
/**
* 禁用:
* 1)全为数字且少于8位
* 2)密码字符全部相同
*/
var disable_msg = "此密码安全性太弱,不可用" ;
if(is_all_num && len < 8){
ops_show(disable_msg,true);
return false;
}
var i=0;
var apwd = pwd.split('');
for(i=1; i < len ; i ++)
if(apwd[i] != apwd[0])
break;
if(i >= len){
ops_show(disable_msg,true);
return false;
}
/**
* 极强:
* 1)数字与字母与其它可打印字符(大于2位)且大于等于8位
*/
if( (have_num && have_abc && is_very_strong && len >= 8) ){
ops_show('<font color="#00cc00">极强</font>');
return true;
}
/**
* 强:
* 1)数字与字母与其它可打印字符且大于等于8位
* 2)数字与字母与其它可打印字符(大于2位)且小于8位
* 3)两两组合大于等于8位
*/
if( (have_num && have_abc && have_strong && len >= 8)
|| (have_num && have_abc && is_very_strong && len < 8)
|| ( ( (have_num && have_strong) || (have_abc && have_strong) ) && len >= 8 ) ){
ops_show('<font color="#00cc00">强</font>');
return true;
}
/**
* 中:
* 1)数字与字母混合且大于等于8位
* 2)数字与字母与其它可打印字符且小于8位
* 3)两两组合
*/
if( (have_num && have_abc && len >= 8) || (have_num && have_abc && have_strong && len < 8)
|| ( (have_num && have_strong) || (have_abc && have_strong) ) ){
ops_show('<font color="#ff9900">密码强度中</font>');
return true;
}
/**
* 弱:
* 1)全部为数字或字母
* 2)数字与字母混合且少于8位
*/
if( (is_all_num || is_all_abc) || (have_num && have_abc && len < 8) ){
ops_show('<font color="#ff0000">密码强度弱</font>');
return true;
}
//其它
ops_show('<font color="#ff0000">密码强度一般</font>');
return true;
} 

以上所述是小编给大家介绍的详解表单验证正则表达式实例(推荐)的相关知识,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

(0)

相关推荐

  • JavaScript使用简单正则表达式的数据验证功能示例

    本文实例讲述了JavaScript使用简单正则表达式的数据验证功能.分享给大家供大家参考,具体如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"&

  • Javascript 正则表达式校验数字的简单实例

    实例如下: $("input[datatype=number]").blur(function () { var str = $(this).val(); if (!isDecimal(str)) { alert("请输入数字"); } }); function isDecimal(str) { if (isInteger(str)) return true; var re = /^[-]{0,1}(\d+)[\.]+(\d+)$/; if (re.test(str

  • 正则表达式小脚本(对输入内容进行处理)

    该小脚本实现的是对输入框内容中取出<img>标签中的src中的内容,然后在原来位置进行替换内容,然后在去除输入内容中的html标签,空格等操作 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> <script> window.onload = function ()

  • js输入框使用正则表达式校验输入内容的实例

    js输入框输入校验 /*用户名称格式判断--用户名只能为下划线.数字.字母或中文长度不超过10个字符*/ function checkUserName(str) { var reg = /^[_0-9a-zA-Z\u4e00-\u9fa5]{1,10}$/; return reg.test(str); } 以上这篇js输入框使用正则表达式校验输入内容的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们.

  • js利用正则表达式检验输入内容是否为网址

    js正则检验输入的是否为网址功能在网页中也是很常见的,友情链接部分.表单填写个人主页的时候,使用JavaScript取验证是否为网址. 这个检验不好写,最好还是使用正则表达式去认证. 规定,输入的东西只能是http://与https://开头,而且必须是网址. 有人说,为何像www.1.com这样的网页不行呢? 这是以免你拿用户输入的东西构造超级链接的时候,a标签中的href属性如果遇不到http://或者https://的东西,那么就会认为是根目录,会在你的网站的网址后面接着写入这个地址再跳转

  • javascript 基于正则表达式的文本框验证代码

    1,不能为空 <input  type="text" onblur="if(this.value.replace(/^ +| +$/g,'')=='')alert('不能为空!')"> 2,只能输入英文和数字<input onblur="if(/[^0-9a-zA-Z]/g.test(value))alert('有错')"><input onkeyup="value=value.replace(/[^0-9

  • js各种验证文本框输入格式(正则表达式)

    不能为空 <input onblur="if(this.value.replace(/^ +| +$/g,'')=='')alert('不能为空!')"> 只能输入英文和数字<input onblur="if(/[^0-9a-zA-Z]/g.test(value))alert('有错')"><input onkeyup="value=value.replace(/[^0-9a-zA-Z]/g,'')"/><

  • javascript中使用正则表达式进行字符串验证示例

    var reg=/正则表达式/: boolean reg.test(要验证的字符串); js引擎会将/正则表达式/""转换成一个RegExp对象,当字符串满足正则表达式的要求事,返回true. 我写的一个表达式验证示例:功能如下: 用户名,不能为空 密码6为数字 密码确认,两次输入密码必须相同 身份证号码必须是15位,或者是18位,最末尾也可以是X(该功能还没有写,有时间再补上) 复制代码 代码如下: <!DOCTYPE html> <html> <hea

  • 详解表单验证正则表达式实例(推荐)

    验证:!reg.test(value) 邮箱: 复制代码 代码如下: reg = /^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/i; 不包含中文: 复制代码 代码如下: reg = /.*[\u4e00-\u9fa5]+.*$/i; 身份证号: // 验证身份证号码 var city = {11:'北京',12:'天津',13:'河北',14:'山西',15:'内蒙古',21:'辽宁',22:'吉

  • 表单验证正则表达式实例代码详解

    表单验证正则表达式具体内容如下所示: 首先给大家解释一些符号相关的意义 1.  /^$/ 这个是个通用的格式. ^ 匹配输入字符串的开始位置:$匹配输入字符串的结束位置 2. 里面输入需要实现的功能. * 匹配前面的子表达式零次或多次:        + 匹配前面的子表达式一次或多次:        ?匹配前面的子表达式零次或一次:        \d  匹配一个数字字符,等价于[0-9] 下面通过一段代码给大家分析表单验证正则表达式,具体代码如下: <!DOCTYPE html> <h

  • JavaScript 表单验证正则表达式大全[推荐]

    具体和函数结合的使用方法,还请查看下篇文章 JavaScript 使用正则表达式进行表单验证的示例代码 复制代码 代码如下: 匹配中文字符的正则表达式: [u4e00-u9fa5] 评注:匹配中文还真是个头疼的事,有了这个表达式就好办了 匹配双字节字符(包括汉字在内):[^x00-xff] 评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1) 匹配空白行的正则表达式:ns*r 评注:可以用来删除空白行 匹配HTML标记的正则表达式:< (S*?)[^>]*>.*?

  • jQuery表单验证插件解析(推荐)

    一:插件 (1) Validform_v5.3.1_min.js Validform_Datatype.js (2)网址:http://validform.rjboy.cn 在这个网站上有demo和插件下载链接. 二:普通验证 (1)Validform_Datatype.js /* Validform datatype extension By sean during December 8, 2012 - February 20, 2013 For more information, pleas

  • jQuery完成表单验证的实例代码(纯代码)

    废话不多说了,直接给大家贴代码了,具体代码如下所示: <!doctype html> <head> <meta charset=utf-8" /> <title>表单验证</title> <link href="css/style1.css" rel="external nofollow" rel="stylesheet" type="text/css"

  • jquery validate.js表单验证入门实例(附源码)

    小编上网查阅了许多关于jquery.validate的文章,大部门只是介绍它的api和用法,没有一个详细的的入门案例介绍,研究了半天还是无从下手.为此,小编自己做了一个jquery validate.js表单验证入门实例,写的不是特别好,但应该适用于初学者,分享给大家. 以下是validate.js表单验证入门实例参考源码,文章下面有源码下载地址: <html> <head> <meta http-equiv="Content-Type" content=

  • layui原生表单验证的实例

    在网上看到很多validform和layer配合的验证方式,但是觉得写的不好,不清不楚的,于是研究了一下layui原生的验证 1. 在需要验证的item上加 lay-verify="value" ,在提交按钮上加 lay-submit lay-filter="go" 两个属性 value: required(必填项) phone(手机号) email(邮箱) url(网址) number(数字) date(日期) identity(身份证) 自定义值(就是自定义验证

  • vue中使用element-ui进行表单验证的实例代码

    element-ui 中验证 一.简单逻辑验证(直接使用rules) 实现思路 •html中给el-form增加 :rules="rules" •html中在el-form-item 中增加属性 prop="名称" •js中直接在data中定义rules:{} •html部分 <el-form ref="form" :rules="rules" :model="form" label-width=&q

  • Vue循环组件加validate多表单验证的实例

    *父父组件(helloWorld.vue): <template> <div class="hello-world"> <el-button type="text" @click="saveAll" class="button">SAVE</el-button> <promise-father ref="promiseFather"></pr

  • React中使用async validator进行表单验证的实例代码

    react中进行表单验证毫无疑问是繁琐的,尤其对于动态添加或删除的表单,其验证逻辑更为复杂, 目前UI框架使用material ui ,但其表单处理不太理想,而后研究了一下另一个UI 框架 ant design, 其对表单的处理大大方便了逻辑的编写, 它使用async-validator处理验证逻辑 目前更换框架毫无疑问是不现实的,于是就想直接引入async-validator,下面描述一个简单的使用,具体信息可以去github上查看 validate.js import Schema from

随机推荐