12个常用的js正则表达式

在这篇文章里,我已经编写了12个超有用的正则表达式,这可是WEB开发人员的最爱哦。

1.在input框中只能输入金额,其实就是只能输入最多有两位小数的数字

//第一种在input输入框限制 
 <input type="text" maxlength="8" class="form-control" id="amount" value="" onChange="count();" onkeyup="if (this.value==this.value2) return; if (this.value.search(/^\d*(?:\.\d{0,2})?$/)==-1) this.value=(this.value2)?this.value2:'';else this.value2=this.value;">元 
//第二种对于表单动态增加的方式,只能在js方法中验证。 
 var amount=$("#amount").val(); 
 if (amount.search(/^\d*(?:\.\d{0,2})?$/)==-1) { 
   alert("金额格式不对,最多有两位小数"); 
   return false; 
} 

2.验证邮箱格式

var reg=/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/; 
 var email=$("#email").val(); 
 if(!reg.test(email) ){ 
    alert("请输入符合规范的邮箱账号!"); 
    return false; 
   } 

3.密码采用数字、字母、特殊字符且长度为8-20位 

function validatePwd(str) { 
if (/^.*?[\d]+.*$/.test(str) && /^.*?[A-Za-z]/.test(str) 
&& /^.*?[~/`!@#$%^&*()_+|{}?;:><\-\]\\[\/].*$/.test(str) && /^.{8,20}$/.test(str)) { 
return true; 
} 
return false; 
} 

4.验证电话号码

/** 
 * 验证电话号码 
 * @param phoneValue 要验证的电话号码 
 * @returns 匹配返回true 不匹配返回false 
 */ 
function validatePhone(phoneValue) { 
 phoneValue = valueTrim(phoneValue); 
 var reg = /^[1][0-9]{10}$/; 
 return reg.test(phoneValue); 
} 

5.判断是否是汉字

/** 
 * 判断是否是汉字 
 * 
 * @param charValue 
 *   要验证的数据 
 * @returns 匹配返回true 不匹配返回false 
 */ 
function isCharacter(charValue) { 
 var reg = /^[\u4e00-\u9fa5]{0,}$/; 
 return reg.test(charValue); 
} 

6.是否为字母:true:是,false:不是

function isChar(charValue){ 
 var charPattern=/^[a-zA-Z]*$/; //是否为字母 
 result=charPattern.test(charValue); 
 return result; 
} 

7.判断是否为数字

function isNum(numValue){ 
 var numPattern=/^\d*$/; //数字的正则表达式 
 result=numPattern.test(numValue); 
 return result; 
} 

8.整数的正则表达式

function isInt(intValue){ 
  var intPattern=/^0$|^[1-9]\d*$/; //整数的正则表达式 
 result=intPattern.test(intValue); 
  return result; 
 } 

9.是否为字母和数字

 function isCharNum(flagValue){ 
 var flagPattern=/^[a-zA-Z0-9]*$/; //是否为字母和数字 
 result=flagPattern.test(flagValue); 
 return result; 
} 

10.检验18位身份证号码 

/** 
 * 检验18位身份证号码(15位号码可以只检测生日是否正确即可,自行解决) 
 * 
 * @param idCardValue 
 *   18位身份证号 
 * @returns 匹配返回true 不匹配返回false 
 */ 
function idCardVildate(cid) { 
var arrExp = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];// 加权因子 
var arrValid = [ 1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2 ];// 校验码 
var reg = /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/; 
if (reg.test(cid)) { 
var sum = 0, idx; 
for (var i = 0; i < cid.length - 1; i++) { 
// 对前17位数字与权值乘积求和 
sum += parseInt(cid.substr(i, 1), 10) * arrExp[i]; 
} 
// 计算模(固定算法) 
idx = sum % 11; 
// 检验第18为是否与校验码相等 
return arrValid[idx] == cid.substr(17, 1).toUpperCase(); 
} else { 
return false; 
} 
} 

11.验证15位数身份证号码中的生日是否是有效生日

function isValidityBrithBy15IdCard(idCard15) { 
 var year = idCard15.substring(6, 8); 
 var month = idCard15.substring(8, 10); 
 var day = idCard15.substring(10, 12); 
 var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day)); 
 // 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法 
 if (temp_date.getYear() != parseFloat(year) 
   || temp_date.getMonth() != parseFloat(month) - 1 
   || temp_date.getDate() != parseFloat(day)) { 
  return false; 
 } else { 
  return true; 
 } 
} 

12.验证18位数身份证号码中的生日是否是有效生日

function isValidityBrithBy18IdCard(idCard18) { 
 var year = idCard18.substring(6, 10); 
 var month = idCard18.substring(10, 12); 
 var day = idCard18.substring(12, 14); 
 var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day)); 
 // 这里用getFullYear()获取年份,避免千年虫问题 
 if (temp_date.getFullYear() != parseFloat(year) 
   || temp_date.getMonth() != parseFloat(month) - 1 
   || temp_date.getDate() != parseFloat(day)) { 
  return false; 
 } else { 
  return true; 
 } 
}

这就是小编整理的web开发中常用的表单验证的正则表达式,希望大家喜欢。

本页内容版权归属为原作者,如有侵犯您的权益,请通知我们删除。
先来看这行代码: script src = "allMyClientSideCode.js"/script 这有点儿……不怎么样。“这该放在哪儿?”开发人员会奇怪,“靠上点,放到head标签里?还是靠下点,放到body标签里?”这两种做法都会让富脚本站点的下场很凄惨。head标签里的大脚本会滞压所有页面渲染工作,使得用户在脚本加载完毕之前一直处于“白屏死机”状态。而body标签末尾的大脚本只会让用户看到毫无生命力的静态页面,原本应该进行客户端渲染的地方却散布着不起作用 的控件和空空如也的方框。 完美解决这

详解JavaScript的回调函数 - 2015-11-21 14:11:04

本文的目录: 什么是回调或高级函数 回调函数是如何实现的 实现回调函数的基本原则 回调地狱的问题和解决方案 实现自己的回调函数 在JavaScrip中,function是内置的类对象,也就是说它是一种类型的对象,可以和其它String、Array、Number、Object类的对象一样用于内置对象的管理。因为function实际上是一种对象,它可以“存储在变量中,通过参数传递给(别一个)函数(function),在函数内部创建,从函数中返回结果值”。 因为function是内置对象,我们可以将它作为参数传
本文实例讲述了js实现模拟银行卡账号输入显示效果。分享给大家供大家参考,具体如下: 先来看运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js/2015/js-mn-bank-card-input-style-codes/ 具体代码如下: script language="javascript" type="text/javascript"function www_jb51_net (BankNo){if (BankNo.value == "") return;var a
在没看下文之前先给大家简单介绍easyui相关知识。 easyui是一种基于jQuery的用户界面插件集合。ddd easyui为创建现代化,互动,JavaScript应用程序,提供必要的功能。 使用easyui你不需要写很多代码,你只需要通过编写一些简单HTML标记,就可以定义用户界面。 easyui是个完美支持HTML5网页的完整框架。 easyui节省您网页开发的时间和规模。 easyui很简单但功能强大的。 通过使用 jQuery EasyUI 可以很容易地添加 Tabs。您只需要调用 'add'
本文实例讲述了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" head meta http-equiv="Conten
如果要做手机号的验证,那么我们需要知道手机号码的号段。 //移动号码归属地支持号段:134 135 136 137 138 139 147 150 151 152 157 158 159 178 182 183 184 187 188 //联通号码归属地支持号段:130 131 132 145 155 156 176 186 //电信号码归属地支持号段:133 153 177 180 181 189 //移动运营商:170 移动: 2G号段(GSM):134-139、150、151、152、158-159
1、string对象中可以传正则的函数介绍 /* match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。 该方法类似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置。 语法 stringObject.match(searchvalue) stringObject.match(regexp) searchvalue 必需。规定要检索的字符串值。 regexp 必需。规定要匹配的模式的 RegExp 对象。如果该参数不是 RegExp 对象

跟我学习javascript的循环 - 2015-11-20 18:11:05

1、优先使用数组而不是Object类型来表示有顺序的集合 ECMAScript标准并没有规定对JavaScript的Object类型中的属性的存储顺序。 但是在使用for..in循环对Object中的属性进行遍历的时候,确实是需要依赖于某种顺序的。正因为ECMAScript没有对这个顺序进行明确地规范,所以每个JavaScript执行引擎都能够根据自身的特点进行实现,那么在不同的执行环境中就不能保证for..in循环的行为一致性了。 比如,以下代码在调用report方法时的结果就是不确定的: functi
本文实例讲述了原生js模拟淘宝购物车实现代码。分享给大家供大家参考。具体如下: 通过JavaScript实现类似与淘宝的购物车效果,包括商品的单选、全选、删除、修改数量、价格计算、数目计算、预览等功能的实现。实现的效果图: 相应的代码: shoppingCart.html !DOCTYPE htmlhtmlhead meta charset = "UTF-8" titleJavaScript实现购物车项目实战/title link rel="stylesheet" type="text/css" href
编写程序前先来了解下身份证号的构成: 身份证号分为两种,旧的为15位,新的为18位。 身份证15位编码规则:dddddd yymmdd xx p 其中 dddddd:地区码 yymmdd: 出生年月日 xx: 顺序类编码,无法确定 p: 性别,奇数为男,偶数为女; 身份证18位编码规则:dddddd yyyymmdd xxx y 其中 dddddd:地区码 yyyymmdd: 出生年月日 xxx:顺序类编码,无法确定,奇数为男,偶数为女 y: 校验码,该位数值可通过前17位计算获得,计算的公式见程序, 一