正则表达式语法:/正则表达式主体/修饰符(可选)
var patt = /John/i;
解析:
/runoob/i 是一个正则表达式。
runoob 是一个正则表达式主体 (用于检索,这里可以是要搜索的字符串也可是正则表达式)。
i 是一个修饰符 (搜索不区分大小写)。
正则表达式的常用函数
和正则表达式配合使用的函数常用的有四种:
1. search();
2. replace();
3. test();
4. exec();
其中search和replace可以不用正则表达式,直接用字符串使用。
search()
用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串,并返回子串的起始位置
方法一:使用正则表达式
var str = "Hi John!";
var n = str.search(/John/i);
console.log(n); // 3
方法二:使用字符串
var str = "Hi John!";
var n = str.search("John");
console.log(n); // 3
replace()
用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。
方法一:使用正则表达式
var str = "Hi John!";
var n = str.replace(/John/i,"singleDog");
console.log(n); // singleDog
方法二:使用字符串
var str = "Hi John!";
var n = str.replace("John","singleDog");
console.log(n); // singleDog
test()
用于检测一个字符串是否匹配某个模式,如果字符串中含有匹配的文本,则返回 true,否则返回 false。
var patt = /John/;
patt.test("My name is John!"); //true
或者
/John/.test("My name is John!")达到同样效果
exec()
用于检索字符串中的正则表达式的匹配。该函数返回一个数组,其中存放匹配的结果。如果未找到匹配,则返回值为 null。
/John/.exec("My name is John!"); //John
正则表达式修饰符
修饰符 可以在全局搜索中不区分大小写:
修饰符 | 描述 |
---|---|
i | 执行对大小写不敏感的匹配。 |
g | 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。 |
m | 执行多行匹配。 |
正则表达式模式
方括号用于查找某个范围内的字符:
表达式 | 描述 |
---|---|
[abc] | 查找方括号之间的任何字符。 |
[0-9] | 查找任何从 0 至 9 的数字。 |
(x | y) | 查找任何以 | 分隔的选项。 |
元字符是拥有特殊含义的字符:
元字符 | 描述 |
---|---|
\d | 查找数字 |
\D | 匹配一个非数字字符。等价于[^0-9] |
\s | 查找空白字符 |
\S | 匹配任何非空白字符 |
\b | 匹配单词边界 |
\uxxxx | 查找以十六进制数 xxxx 规定的 Unicode 字符 |
\b | 匹配一个单词边界,也就是指单词和空格间的位置。例如,“er\b”可以匹配“never”中的“er”,但不能匹配“verb”中的“er” |
\B | 匹配非单词边界。“er\B”能匹配“verb”中的“er”,但不能匹配“never”中的“er” |
\w | 匹配包括下划线的任何单词字符。等价于“[A-Za-z0-9_]” |
\W | 匹配任何非单词字符。等价于“[^A-Za-z0-9_]” |
量词:
量词 | 描述 |
---|---|
n+ | 匹配任何包含至少一个 n 的字符串 |
n* | 匹配任何包含零个或多个 n 的字符串 |
n? | 匹配任何包含零个或一个 n 的字符串 |
\ | 将下一个字符标记为一个特殊字符、或一个原义字符、或一个向后引用(灰常重要的作用)、或一个八进制转义符。例如,“n”匹配字符“n”。“\n”匹配一个换行符。串行“\ \”匹配“\”而“\ (”则匹配“(” |
^ | 匹配输入字符串的开始位置。如果设置了RegExp对象的Multiline属性,^也匹配“\n”或“\r”之后的位置 |
$ | 匹配输入字符串的结束位置。如果设置了RegExp对象的Multiline属性,$也匹配“\n”或“\r”之前的位置 |
. | 匹配除“\n”之外的任何单个字符。要匹配包括“\n”在内的任何字符,请使用像“(.|\n)”的模式 |
常用正则表达式
描述 | 正则表达式 |
---|---|
URL | /^(https?:\/\/)?([\da-z.-]+).([a-z.]{2,6})([\/\w .-])\/?$/ |
Unicode编码中的汉字范围 | /^[\u2E80-\u9FFF]+$/ |
十六进制值 | /^#?([a-f0-9]{6} |
更详细请看菜鸟教程