正则表达式有什么作用呢?
它可以:
•测试字符串的某个模式。例如,可以对一个输入字符串进行测试,看在该字符串是否存在一个电话号码模式或一个信用卡号码模式。这称为数据有效性验证 ;•替换文本。可以在文档中使用一个正则表达式来标识特定文字,然后可以全部将其删除,或者替换为别的文字;
•根据模式匹配从字符串中提取一个子字符串。可以用来在文本或输入字段中查找特定文字;
下一篇给出实例,来讲解如何运用下面这些规则。
方括号
方括号用于查找某个范围内的字符:
[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 规定的字符。 |
@L_404_16@ | 查找以十六进制数 xxxx 规定的 Unicode 字符。 |
量词
n+ | 匹配任何包含至少一个 n 的字符串。 |
---|---|
n* | 匹配任何包含零个或多个 n 的字符串。 |
n? | 匹配任何包含零个或一个 n 的字符串。 |
n{X} | 匹配包含 X 个 n 的序列的字符串。 |
n{X,Y} | 匹配包含 X 或 Y 个 n 的序列的字符串。 |
匹配包含至少 X 个 n 的序列的字符串。 | |
n$ | 匹配任何结尾为 n 的字符串。 |
^n | 匹配任何开头为 n 的字符串。 |
?=n | 匹配任何其后紧接指定字符串 n 的字符串。 |
?!n | 匹配任何其后没有紧接指定字符串 n 的字符串。 |
RegExp 对象属性
描述 | FF | IE | ||||||
---|---|---|---|---|---|---|---|---|
global | RegExp 对象是否具有标志 g。 | 1 | 4 | |||||
ignoreCase | RegExp 对象是否具有标志 i。 | lastIndex | 一个整数,标示开始下一次匹配的字符位置。 | multiline | RegExp 对象是否具有标志 m。 | source | 正则表达式的源文本。 | 4 |