JavaScript中的正则表达式用RegExp 对象表示,可以使用RegExp ()构造函数来创建RegExp对象,不过RegExp 对象更多的是通过一种特殊的直接量愈发来创建。
例如:var pattern=/s$/;
参数 pattern 是一个字符串,指定了正则表达式的模式或其他正则表达式。
创建 RegExp 对象的语法:
new RegExp(pattern, attributes);
? 直接量字符
在正则表达式中所以字母与数据都是按照字面含义进行匹配的。JavaScript正则表达式也支持非字母的字符匹配,这些字符需要通过反斜杠(\)作为前缀进行转义。
| 字符 | 匹配 |
| 字母和数字 | 自身 |
| \o | NUL字符 |
| \t | 制表符 |
| \n | 换行符 |
| \v | 垂直制表符 |
| \f | 换页符 |
| \r | 回车符 |
| \xnn | 由十六进制nn指定的拉丁字符 |
| \uxxxx | 由十六进制xxxx指定的Unicode字符 |
| \cX | 控制字符cX |
特殊含义的标点符号,也需要\为前缀进行匹配:
^ $ . * + ? = ! : | \ / ( ) { } [ ]
? 字符类
正则表达式字符类
| 字符 | 匹配 |
| […] | 方括号内的任意字符 |
| [^…] | 不方括号内的任意字符 |
| . | 除了换行符和其他Unicode行终止符之外的任意字符 |
| \w | 任何ASCII字符组成的单词,等价于[a-zA-Z0-9] |
| \W | 任何不是ASCII字符组成的单词,等价于[^a-zA-Z0-9] |
| \s | 任何Unicode字符空白符 |
| \S | 任何非Unicode字符空白符的字符,注意\S与\w不同 |
| \d | 任何ASCII数字,等价于[0-9] |
| \D | 除了ASCII数字之外的任何字符,等价于[^0-9] |
| [\b] | 退格直接量(特例) |
? 重复
正则表达式的重复字符语法
| 字符 | 含义 |
| {n,m} | 匹配前一项至少n次,但是不超过m次 |
| {n, } | 匹配前一项n次或者多次 |
| {n} | 匹配前一项n次 |
| ? | 匹配前一项0次或1次,等价于{0,1} |
| + | 匹配前一项至少1次或多次,等价于{1, } |
| * | 匹配前一项至少0次或多次,等价于{0, } |
注意:* 和 ?慎用,可能出现允许什么都不匹配。
(补充:非贪婪匹配:以上的重复,我们称之为贪婪匹配。非贪婪匹配即是在,待匹配的字符后跟随一个问号即可。“??”、“+?”、“{1,5}?”,?表达的是在匹配字符串时,匹配尽量更短的匹配。)
? 选择、分组和引用
()圆括号的作用:
1.把单独的项组合成子表达式,以便可以处理一个独立的单元那样使用 “|”、“*”、“+”或者“?”
例如:/(ab|cd)+|ef/ :表示可以匹配字符串“ef”,也可以匹配字符串“ab”或“cd”的一次或多次
2.在完整的模式中定义子模式
3.允许在同一正则表达式的后部引用前面的子表达式,通过在字符“\”加数字实现。
例如:/([‘ “][^’ “]*\1)/:\1匹配的是第一个带圆括号的子表达式所匹配的模式。在这样的表达式里,就可以是左侧的引号必须和右侧的引号相匹配。
不会出现单双引号串用。
| 字符 | 含义 |
| | | 选择,匹配的是该符号左边的子表达式或右边的子表达式 |
| (…) | 组合,将几个项组合为一个单元,这个单元可通过“|”、“*”、“+”或者“?”等符号修饰,而且可以记住和这个组合匹配的字符串以供此后引用 |
| (?:…) | 只组合,把项目组合到一个单元,但不记忆与该组相匹配的字符 |
| \n | 和第n个分组第一次匹配的字符相匹配,组是圆括号的子表达式(也可以是嵌套的),组索引是从左到右的左括号数,(“?:”形式的分组不编码 |
? 指定匹配字符位置
正则表达式中的锚字符
| 字符 | 含义 |
| ^ | 匹配字符串的开头,在多行检索中,匹配一行的开头 |
| $ | 匹配字符串的结尾,在多行检索中,匹配一行的结尾 |
| \b | 匹配一个单纯的编辑,简言之,就是位于字符\w和\W之间的位置,或位于字符\w和字符串的开头或者结尾之间的位置(单需注意,[\b]匹配的是退格符) |
| \B | 匹配非单词边界的位置 |
| (?=p) | 零宽正向先行短语,要求接下来的字符都与P匹配,但不能包括匹配p的那些字符 |
| (?!p) | 零宽负向先行短语,要求接下来的字符不与P匹配 |
| 字符 | 含义 |
| g | 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。 |
| i | 执行对大小写不敏感的匹配。 |
| m | 执行多行匹配 |
验证数字:^[0-9]*$
验证n位的数字:^\d{n}$
验证至少n位数字:^\d{n,}$
验证m-n位的数字:^\d{m,n}$
验证零和非零开头的数字:^(0|[1-9][0-9]*)$
验证有两位小数的正实数:^[0-9]+(.[0-9]{2})?$
验证有1-3位小数的正实数:^[0-9]+(.[0-9]{1,3})?$
验证非零的正整数:^\+?[1-9][0-9]*$
验证非零的负整数:^\-[1-9][0-9]*$
验证非负整数(正整数 + 0):^\d+$
验证非正整数(负整数 + 0):^((-\d+)|(0+))$
验证长度为3的字符:^.{3}$
验证由26个英文字母组成的字符串:^[A-Za-z]+$
验证由26个大写英文字母组成的字符串:^[A-Z]+$
验证由26个小写英文字母组成的字符串:^[a-z]+$
验证由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$
验证由数字、26个英文字母或者下划线组成的字符串:^\w+$
验证用户密码:^[a-zA-Z]\w{5,17}$
正确格式为:以字母开头,长度在6-18之间,只能包含字符、数字和下划线。
验证是否含有 ^%&‘,;=?$\" 等字符:[^%&‘,;=?$\x22]+
验证汉字:^([\u4e00-\u9fa5]{0,})$
验证Email地址:^\w+([-.]\w+)*@\w+([-.]\w+)+(\.\w+[-.]\w+)*$
验证InternetURL:
^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$ ;^[a-zA-z]+://(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$
验证电话号码:
^(\(\d{3,4}\)|\d{3,4}-)?\d{7,8}$:--正确格式为:XXXX-XXXXXXX,XXXX-XXXXXXXX,XXX-XXXXXXX,XXX-XXXXXXXX,XXXXXXX,XXXXXXXX。
验证身份证号(15位或18位数字):^\d{15}|\d{18}$
验证一年的12个月:^(0?[1-9]|1[0-2])$ 正确格式为:“01”-“09”和“1”“12”
验证一个月的31天:^((0?[1-9])|((1|2)[0-9])|30|31)$ 正确格式为:01、09和1、31。
原文:http://www.cnblogs.com/xuyuanyuan/p/4712668.html