正则表达式全攻略(一)

"^[A-Za-z0-9]+$"  //由数字和26个英文字母组成的字符串   
"^//w+$"  //由数字、26个英文字母或者下划线组成的字符串   
"^[//w-]+(//.[//w-]+)*@[//w-]+(//.[//w-]+)+$"    //email地址  


“+”元字符规定其前导字符必须在目标对象中连续出现一次或多次。

“*”元字符规定其前导字符必须在目标对象中出现零次或连续多次。

“?”元字符规定其前导对象必须在目标对象中连续出现零次或一次。

{n} n 是一个非负整数。匹配确定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',但是能匹配 "food" 中的两个 o。

{n,} n 是一个非负整数。至少匹配 n 次。例如,'o{2,}' 不能匹配 "Bob" 中的 'o',但能匹配 "foooood" 中的所有 o。'o{1,}' 等价于 'o+'。'o{0,}' 则等价于 'o*'。

{n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。例如,"o{1,3}" 将匹配 "fooooood" 中的前三个 o。'o{0,1}' 等价于 'o?'。请注意在逗号和两个数之间不能有空格。

/s:用于匹配单个空格符,包括tab键和换行符;   
/S:用于匹配除单个空格符之外的所有字符;   
/d:用于匹配从0到9的数字;   
/w:用于匹配字母,数字或下划线字符;   
/W:用于匹配所有与/w不匹配的字符;   
. :用于匹配除换行符之外的所有字符。   

 下面,我们就通过实例看一下如何在正则表达式中使用上述元字符。
//s+/ 上述正则表达式可以用于匹配目标对象中的一个或多个空格字符。
//d000/ 如果我们手中有一份复杂的财务报表,那么我们可以通过上述正则表达式轻而易举的查找到所有总额达千元的款项。
除了我们以上所介绍的元字符之外,正则表达式中还具有另外一种较为独特的专用字符,即定位符。定位符用于规定匹配模式在目标对象中的出现位置。 较为常用的定位符包括: “^”, “$”, “/b” 以及 “/B”。

代码

“^”定位符规定匹配模式必须出现在目标字符串的开头   
“$”定位符规定匹配模式必须出现在目标对象的结尾   
“/b”定位符规定匹配模式必须出现在目标字符串的开头或结尾的两个边界之一   
“/B”定位符则规定匹配对象必须位于目标字符串的开头和结尾两个边界之内,   
      即匹配对象既不能作为目标字符串的开头,也不能作为目标字符串的结尾。   

同样,我们也可以把“^”和“$”以及“/b”和“/B”看作是互为逆运算的两组定位符。举例来说: /^hell/ 因为上述正则表达式中包含“^”定位符,所以可以与目标对象中以 “hell”, “hello”或“hellhound”开头的字符串相匹配。 /ar$/ 因为上述正则表达式中包含“$”定位符,所以可以与目标对象中以 “car”, “bar”或 “ar” 结尾的字符串相匹配。 //bbom/ 因为上述正则表达式模式以“/b”定位符开头,所以可以与目标对象中以 “bomb”, 或 “bom”开头的字符串相匹配。/man/b/ 因为上述正则表达式模式以“/b”定位符结尾,所以可以与目标对象中以 “human”, “woman”或 “man”结尾的字符串相匹配。
为了能够方便用户更加灵活的设定匹配模式,正则表达式允许使用者在匹配模式中指定某一个范围而不局限于具体的字符。例如:

代码

/[A-Z]/  上述正则表达式将会与从A到Z范围内任何一个大写字母相匹配。  
/[a-z]/  上述正则表达式将会与从a到z范围内任何一个小写字母相匹配。   
/[0-9]/  上述正则表达式将会与从0到9范围内任何一个数字相匹配。   
/([a-z][A-Z][0-9])+/ 上述正则表达式将会与任何由字母和数字组成的字符串,如 “aB0” 等相匹配。

 
使用举例:

<html>   
<head>   
  <script language="Javascript1.2">   
     <!-- start hiding   
     function verifyAddress(obj)   
     {   
            alert("OK");
      var email = obj.email.value;   
      var pattern =  /
^[//w-]+(//.[//w-]+)*@[//w-]+(//.[//w-]+)+$ /;   
      var flag = pattern.test(email);
        if(flag)   
      {   
       alert("Your email address is correct!");   
       return true;   
      }   
      else   
       {   
        alert("Please try again!");   
        return false;   
        } 
      }   
     // stop hiding -->   
    </script>   
  </head>   
  <body>   
   <form onSubmit="return verifyAddress(this);">   
    <input name="email" type="text">   
    <input type="submit">   
    </form>   
  </body>   
</html>  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值