常用正则验证

  一、IP地址校验
  /*
  用途:校验ip地址的格式
  输入:strIP:ip地址
  返回:如果通过验证返回true,否则返回false;
  */
  function isIP(strIP) {
  if (isNull(strIP)) return false;
  var re=/^(\d+)\.(\d+)\.(\d+)\.(\d+)$/g //匹配IP地址的正则表达式
  if(re.test(strIP)){
  if( RegExp.$1 正则表达式。
  RegExp.$1是RegExp的一个属性,指的是与正则表达式匹配的第一个 子匹配(以括号为标志)字符串,以此类推,RegExp.$2,RegExp.$3,..RegExp.$99总共可以有99个匹配
  给你看了例子就知道了
  var r= /^(\d{4})-(\d{1,2})-(\d{1,2})$/; //正则表达式 匹配出生日期(简单匹配)
  r.exec('1985-10-15');
  s1=RegExp.$1;
  s2=RegExp.$2;
  s3=RegExp.$3;
  alert(s1+" "+s2+" "+s3)//结果为1985 10 15
  RegExp 对象
  RegExp 对象表示正则表达式,它是对字符串执行模式匹配的强大工具。
  直接量语法
  /pattern/attributes
  创建 RegExp 对象的语法:
  new RegExp(pattern, attributes);
  参数
  参数 pattern 是一个字符串,指定了正则表达式的模式或其他正则表达式。
  参数 attributes 是一个可选的字符串,包含属性 "g"、"i" 和 "m",分别用于指定全局匹配、区分大小写的匹配和多行匹配。ECMAScript 标准化之前,不支持 m 属性。如果 pattern 是正则表达式,而不是字符串,则必须省略该参数。
  返回值
  一个新的 RegExp 对象,具有指定的模式和标志。如果参数 pattern 是正则表达式而不是字符串,那么 RegExp() 构造函数将用与指定的 RegExp 相同的模式和标志创建一个新的 RegExp 对象。
  如果不用 new 运算符,而将 RegExp() 作为函数调用,那么它的行为与用 new 运算符调用时一样,只是当 pattern 是正则表达式时,它只返回 pattern,而不再创建一个新的 RegExp 对象。
  抛出
  SyntaxError - 如果 pattern 不是合法的正则表达式,或 attributes 含有 "g"、"i" 和 "m" 之外的字符,抛出该异常。
  TypeError - 如果 pattern 是 RegExp 对象,但没有省略 attributes 参数,抛出该异常。
  修饰符
  修饰符 描述
  i
  执行对大小写不敏感的匹配。
  g
  执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。
  m 执行多行匹配。
  方括号
  方括号用于查找某个范围内的字符:
  表达式 描述
  [abc]
  查找方括号之间的任何字符。
  [^abc]
  查找任何不在方括号之间的字符。
  [0-9] 查找任何从 0 至 9 的数字。
  [a-z] 查找任何从小写 a 到小写 z 的字符。
  [A-Z] 查找任何从大写 A 到大写 Z 的字符。
  [a-Z] 查找任何从小写 a 到大写 Z 的字符。
  [adgk] 查找给定集合内的任何字符。
  [^adgk] 查找给定集合外的任何字符。
  [red|blue|green] 查找任何指定的选项。
  元字符
  元字符(Metacharacter)是拥有特殊含义的字符:
  元字符 描述
  .
  查找单个字符,除了换行和行结束符。
  \w
  查找单词字符。
  \W
  查找非单词字符。
  \d
  查找数字。
  \D
  查找非数字字符。
  \s
  查找空白字符。
  \S
  查找非空白字符。
  \b
  查找位于单词的开头或结尾的匹配。
  \B
  查找不处在单词的开头或结尾的匹配。
  \0 查找 NUL 字符。
  \n
  查找换行符。
  \f 查找换页符。
  \r 查找回车符。
  \t 查找制表符。
  \v 查找垂直制表符。
  \xxx
  查找以八进制数 xxx 规定的字符。
  \xdd
  查找以十六进制数 dd 规定的字符。
  \uxxxx
  查找以十六进制数 xxxx 规定的 Unicode 字符。
  量词
  量词 描述
  n+
  匹配任何包含至少一个 n 的字符串。
  n*
  匹配任何包含零个或多个 n 的字符串。
  n?
  匹配任何包含零个或一个 n 的字符串。
  n{X}
  匹配包含 X 个 n 的序列的字符串。
  n{X,Y}
  匹配包含 X 或 Y 个 n 的序列的字符串。
  n{X,}
  匹配包含至少 X 个 n 的序列的字符串。
  n$
  匹配任何结尾为 n 的字符串。
  ^n
  匹配任何开头为 n 的字符串。
  ?=n
  匹配任何其后紧接指定字符串 n 的字符串。
  ?!n
  匹配任何其后没有紧接指定字符串 n 的字符串。
  RegExp 对象属性
  FF: Firefox, IE: Internet Explorer
  属性 描述 FF IE
  global
  RegExp 对象是否具有标志 g。 1 4
  ignoreCase
  RegExp 对象是否具有标志 i。 1 4
  lastIndex
  一个整数,标示开始下一次匹配的字符位置。 1 4
  multiline
  RegExp 对象是否具有标志 m。 1 4
  source
  正则表达式的源文本。 1 4
  RegExp 对象方法
  FF: Firefox, IE: Internet Explorer
  方法 描述 FF IE
  compile
  编译正则表达式。 1 4
  exec
  检索字符串中指定的值。返回找到的值,并确定其位置。 1 4
  test
  检索字符串中指定的值。返回 true 或 false。 1 4
  支持正则表达式的 String 对象的方法
  FF: Firefox, IE: Internet Explorer
  方法 描述 FF IE
  search
  检索与正则表达式相匹配的值。 1 4
  match
  找到一个或多个正则表达式的匹配。 1 4
  replace
  替换与正则表达式匹配的子串。 1 4
  split
  把字符串分割为字符串数组。
  二、检查输入字符串是否为空或者全部都是空格
  /*
  用途:检查输入字符串是否为空或者全部都是空格
  输入:str
  返回:如果全是空返回true,否则返回false
  */
  function isNull( str ){
  if ( str == "" ) return true;
  var regu = "^[ ]+$";
  var re = new RegExp(regu);
  return re.test(str);
  }
  三、检查输入手机号码是否正确
  /*
  用途:检查输入手机号码是否正确
  输入:
  s:字符串
  返回:
  如果通过验证返回true,否则返回false
  */
  function checkMobile( s ){
  var regu =/^[1][3][0-9]{9}$/;
  var re = new RegExp(regu);
  if (re.test(s)) {
  return true;
  }else{
  return false;
  }
  }
  四、检查输入对象的值是否符合整数格式
  /*
  用途:检查输入对象的值是否符合整数格式
  输入:str 输入的字符串
  返回:如果通过验证返回true,否则返回false
  */
  function isInteger( str ){
  var regu = /^[-]{0,1}[0-9]{1,}$/;
  return regu.test(str);
  }
  五、
  /*
  用途:检查输入字符串是否符合正整数格式
  输入:
  s:字符串
  返回:
  如果通过验证返回true,否则返回false
  */
  function isNumber( s ){
  var regu = "^[0-9]+$";
  var re = new RegExp(regu);
  if (s.search(re) != -1) {
  return true;
  } else {
  return false;
  }
  }
  六、
  /*
  用途:检查输入字符串是否是带小数的数字格式,可以是负数
  输入:
  s:字符串
  返回:
  如果通过验证返回true,否则返回false
  */
  function isDecimal( str ){
  if(isInteger(str)) return true;
  var re = /^[-]{0,1}(\d+)[\.]+(\d+)$/;
  if (re.test(str)) {
  if(RegExp.$1==0&&RegExp.$2==0) return false;
  return true;
  } else {
  return false;
  }
  }
  七、
  /*
  用途:检查输入对象的值是否符合端口号格式
  输入:str 输入的字符串
  返回:如果通过验证返回true,否则返回false
  */
  function isPort( str ){
  return (isNumber(str) && str"2100" || year"12" || monthgetMaxDay(year,month) || day=起始日期
  输入:
  startDate:起始日期,字符串
  endDate:结束如期,字符串
  返回:
  如果通过验证返回true,否则返回false
  */
  function checkTwoDate( startDate,endDate ) {
  if( !isDate(startDate) ) {
  alert("起始日期不正确!");
  return false;
  } else if( !isDate(endDate) ) {
  alert("终止日期不正确!");
  return false;
  } else if( startDate > endDate ) {
  alert("起始日期不能大于终止日期!");
  return false;
  }
  return true;
  }
  十九、
  /*
  用途:检查输入的Email信箱格式是否正确
  输入:
  strEmail:字符串
  返回:
  如果通过验证返回true,否则返回false
  */
  function checkEmail(strEmail) {
  //var emailReg = /^[_a-z0-9]+@([_a-z0-9]+\.)+[a-z0-9]{2,3}$/;
  var emailReg = /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/;
  if( emailReg.test(strEmail) ){
  return true;
  }else{
  alert("您输入的Email地址格式不正确!");
  return false;
  }
  }
  二十、
  /*
  用途:检查输入的电话号码格式是否正确
  输入:
  strPhone:字符串
  返回:
  如果通过验证返回true,否则返回false
  */
  function checkPhone( strPhone ) {
  var phoneRegWithArea = /^[0][1-9]{2,3}-[0-9]{5,10}$/;
  var phoneRegNoArea = /^[1-9]{1}[0-9]{5,8}$/;
  var prompt = "您输入的电话号码不正确!"
  if( strPhone.length > 9 ) {
  if( phoneRegWithArea.test(strPhone) ){
  return true;
  }else{
  alert( prompt );
  return false;
  }
  }else{
  if( phoneRegNoArea.test( strPhone ) ){
  return true;
  }else{
  alert( prompt );
  return false;
  }
  }
  }
  二十一、
  /*
  用途:检查复选框被选中的数目
  输入:
  checkboxID:字符串
  返回:
  返回该复选框中被选中的数目
  */
  function checkSelect( checkboxID ) {
  var check = 0;
  var i=0;
  if( document.all(checkboxID).length > 0 ) {
  for( i=0; i<document.all(checkboxID).length; i++ ) {
  if( document.all(checkboxID).item( i ).checked ) {
  check += 1;
  }
  }
  }else{
  if( document.all(checkboxID).checked )
  check = 1;
  }
  return check;
  }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值