js正则表达式
在 JavaScript 中,正则表达式常用于两个字符串方法:search() 和 replace()。
search() 方法使用表达式来搜索匹配,然后返回匹配的位置。
replace() 方法返回模式被替换处修改后的字符串。
search()方法
search() 方法也接受字符串作为搜索参数。找到则返回其索引,否则返回-1。
字符串参数将被转换为正则表达式,如
var str = "Visit W3School!";
var n = str.search("W3School");
在search()中使用正则表达式
使用正则表达式的修饰符i,可以忽略大小写。如,执行搜索字符串中 “w3school” 的大小写不敏感的搜索:
var str = "Visit W3School";
var n = str.search(/w3school/i);
replace()方法
replace() 也接受字符串作为搜索参数,第一个参数为被替换者,第二个则是要替换成的结果
var str = "Visit Microsoft!";
var res = str.replace("Microsoft", "W3School");
在replace()中使用正则表达式
var str = "Visit Microsoft!";
var res = str.replace(/microsoft/i, "W3School");
正则表达式修饰符
正则在各个语言中,实现的标准并不完全一致。
四个修饰符
在 JavaScript 中,正则有四个修饰符: global, ignoreCase, multiline, unicode,它们的含义如下:
- global(g) 针对字符串中所有可能的匹配来测试正则表达式
- ignoreCase(i) 匹配时忽略大小写
- multiline(m) 多行输入将被视为多行(此时开始^和结尾匹配$可以在每行中进行匹配)
- unicode(u) 对字符串采用unicode进行匹配
g修饰符和RegExp.prototype.exec()方法
返回值是一个数组,除了匹配到的元素之外,还有一个index属性
如果不加 g,每次都是从索引0处开始查找。
加上g后index 是在变化的,当找不到匹配项时,会返回 null,并且每次都从index处开始查找。因此:
var r = /\d/g;
console.log(r.exec('12')); // ["1", index: 0, input: "12"]
console.log(r.exec('12')); // ["2", index: 1, input: "12"]
console.log(r.exec('12')); // null
console.log(r.exec('12')); // ["1", index: 0, input: "12"]
正则表达式模式
括号
括号用于查找一定范围的字符串:
-
中括号[] 表示字符集合,如匹配其中的任何字符
var reg = /1$/
-
大括号{}量词符,里面表示重复次数,如
var reg = /^abc{3}$/; // 匹配有3个c的字符串
-
小括号()表示优先级,如
var reg = /^(abc){3}$/ //匹配有三个abc的字符串
元字符
元字符(Metacharacter)是拥有特殊含义的字符:
- \d 匹配0-9之间的任何数字 相当于[0-9]
- \D 匹配0-9以外的字符 相当于[^0-9]
- \w 匹配任意的字母、数字和下划线 相当于[A-Za-z0-9_]
- \W 匹配除字母、数字和下划线以外的字符 相当于[^A-Za-z0-9_]
- \s 匹配空字符串 相当于[\t\r\n\v\f]
- \S 匹配非空字符串 相当于[^\t\r\n\v\f]
- \b 匹配单词边界
- \uxxxx 查找以十六进制数xxxx规定的Unicode字符
量词
- n+ 匹配任何包含至少一个 n 的字符串。
- n* 匹配任何包含零个或多个 n 的字符串。
- n? 匹配任何包含零个或一个 n 的字符串。
abc ↩︎