构造正则表达式
var ex = /[abcd]/gi; //通过字面常量的方式,一对正斜杠中间写表达式内容,后面可以跟修饰符。
var re = new RegExp("[abcd]","gi"); //通过构造函数的方式,第一个参数是表达式内容,第二个参数是修饰符
修饰符:
i 执行大小写不敏感的匹配
g 执行全局匹配,即返回所有匹配的子串,默认只返回第一个匹配
m 多行匹配,^ 和 $ 在字符串的每一行都进行一次匹配。
元字符:
( [ { ^ $ | ) ? * + .
在字面意义和特殊意义之间进行转换,例如/表示字符/。
^ 匹配字符串的开头,例如
$ 匹配字符串的结尾
() 小括号里面的元素结合为一组,可以在后面引用它
[] 匹配字符集中的一个字符,例如[abc]表示匹配字符a或b或c;[^abc]表示匹配不等于a或b或c的字符;[a-e]匹配在a到e范围内的字符;[a-b0-9A-Z_]匹配字母数字和下划线。
| 或操作,例如(jpg|png)表示匹配字符串jpg或字符串png。
{} 表示前面的字符应该出现的次数。{n}表示出现n次;{n,}表示至少出现n次;{n,m}表示出现n次到m次。
* 匹配前面的子表达式零次或多次。例如,zo* 能匹配 "z" 以及 "zoo"。 * 等价于{0,}。
+ 匹配前面的子表达式一次或多次。例如,'zo+' 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等价于 {1,}。
? 匹配前面的子表达式零次或一次。例如,"do(es)?" 可以匹配 "do" 或 "does" 中的"do" 。? 等价于 {0,1}。
大部分元字符与自己最近的元素或组相结合,除了|字符与它所在的组内的前后所有元素相结合。
默认情况下对于出现次数的匹配都采用贪婪匹配的方式,即尽可能地多匹配。例如用/a+/匹配字符串"aaaaaa",将匹配"aaaaaa"而不是"a"。
在次数匹配字符后面加?可将贪婪匹配改为谨慎匹配,例如/a+?/匹配字符串"aaaaaa",将匹配"a"。
预定义类:
. IE下[^
],其它[^
] 匹配除换行符之外的任何一个字符
d [0-9] 匹配数字
D [^0-9] 匹配非数字字符
s [
fx0B] 匹配一个空白字符
S [^
fx0B] 匹配一个非空白字符
w [a-zA-Z0-9_] 匹配字母数字和下划线
W [^a-zA-Z0-9_] 匹配除字母数字下划线之外的字符
注:若要匹配字符串中的换行符可以使用[sS]进行匹配;
正则匹配举例
验证电子邮件:/^w+([.-]?w+)*@w+([.-]?w+)*(.w{2,3})+$/
以w起头,随后可以包含任意数量的“。”或“-”只要他们之间有一个或多个w分隔即可(对应于域名检测);
用户名之后带一个@字符;
以w起头,随后可以包含任意数量的“。”或“-”只要他们之间有一个或多个w分隔即可(对应于邮箱地址检测);
//以“.”加上2到3个“w”结尾。(对应于邮箱地址后缀的检测例如“.com”,“.cn”等)。
验证文件路径:/^(http|https|file)://S+/S+/i
文件路径使用http或https或file开头,后跟://
然后是任意个非空字符表示的文件路径
最后是/加上任意非空字符表示的文件名
修饰符i忽略大小写
正则表达式的使用
RegExp类:
RegExp.source 返回正则表达式的内容
RegExp.test(s) 测试字符串s是否与正则表达式项匹配
RegExp.exec(s) 匹配字符串s,返回匹配到的子串和各个组匹配到的子串的数组,若没有匹配到任何子串则返回null
RegExp.lastIndex 返回最近一次匹配到的位置。默认值为-1
String类:
String.search(re) //返回re匹配到的第一个位置,若不匹配则返回-1。
String.match(re) //返回re匹配到的所有子串的数组,若不匹配返回null。
String.split(re) //用正则表达式匹配到的所有子串来将字符串分割为字符串数组。
String.replace(re, s) //将re匹配到的字符替换为s。(replace方法的第二个参数也可以是函数)
s可以反向引用匹配到的组例如"$2"可反向引用第二次匹配到的字符串,写成str.replace(re, "$2, $1");
(?:pattern)
|
非获取匹配,匹配pattern但不获取匹配结果,不进行存储供以后使用。这在使用或字符“(|)”来组合一个模式的各个部分是很有用。例如“industr(?:y|ies)”就是一个比“industry|industries”更简略的表达式。
|
(?=pattern)
|
非获取匹配,正向肯定预查,在任何匹配pattern的字符串开始处匹配查找字符串,该匹配不需要获取供以后使用。例如,“Windows(?=95|98|NT|2000)”能匹配“Windows2000”中的“Windows”,但不能匹配“Windows3.1”中的“Windows”。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始。
|
(?!pattern)
|
非获取匹配,正向否定预查,在任何不匹配pattern的字符串开始处匹配查找字符串,该匹配不需要获取供以后使用。例如“Windows(?!95|98|NT|2000)”能匹配“Windows3.1”中的“Windows”,但不能匹配“Windows2000”中的“Windows”。
|
(?<=pattern)
|
非获取匹配,反向肯定预查,与正向肯定预查类似,只是方向相反。例如,“(?<=95|98|NT|2000)Windows”能匹配“2000Windows”中的“Windows”,但不能匹配“3.1Windows”中的“Windows”。
|
(?<!pattern)
|
非获取匹配,反向否定预查,与正向否定预查类似,只是方向相反。例如“(?<!95|98|NT|2000)Windows”能匹配“3.1Windows”中的“Windows”,但不能匹配“2000Windows”中的“Windows”。这个地方不正确,有问题
|