ECMAScript通过RegExp类型支持正则表达式,文章或包括两部分,第一部分是使用规则说明,第二部分则是常用方法
使用规则
标志说明
- g:全局模式,模式被应用于所有字符串,而非发现第一个匹配就立即停止
- i 不区分大小写
- m 多行匹配
- s 单行匹配
规则解释
基本字符
- . 匹配除换行符外所有字符
- | 逻辑或操作符
- [] 匹配的字符集合
- [^] 不能匹配的字符集合
-
- 定义一个区间,用于字符集合内(例如[A-Z])
- \ 对下一个字符进行转义(例如.代表匹配字符)
数量元字符
*匹配前一个字符或子表达式0次或多次重复
+ 匹配前一个字符或子表达式1次或多次重复
+? +的懒惰型版本
? 匹配前一个字符或子表达式0次或1次重复
{n} 匹配前一个字符或子表达式n次重复
{m,n} 匹配前一个字符或子表达式至少m次至多n次重复
{n,} 匹配前一个字符或子表达式至少n次
{n,}? {n,}的懒惰型版本
位置元字符
- ^ 匹配字符串的开头
- $ 匹配字符串的结束
- \b 匹配单词的边界
特殊元字符
- \d 匹配任意数字字符
- \n 换行符
- \r 回车符
- \s 匹配一个空白字符
- \t 制表符(Tab字符)
- \w 匹配任意数字、字母、下划线字符
反义字符
- \B 除掉\b之外的所有字符
- \D 除掉\d之外的所有字符
- \S 除掉\s之外的所有字符
- \W 除掉\w之外的所有字符
常用方法
1.test()
作用:检索字符串中的值是否匹配给出的正则规则,返回布尔值true或false
用法
RegExpObject.test(string)
//检索“12”是否匹配前面的正则表达式/../
/../.test("12") //true
2.exec()
作用:检索字符串中的指定值,若找到匹配的文本,则返回一个结果的数组,反之则返回null
用法
RegExpObject.exec(string)
//检索正则表达式/abc/是否在字符串defaabc中匹配到,返回匹配到内容,索引值,以及检索的字符串
/abc/.exec("123aabc") //["abc", index: 4, input: "defaabc", groups: undefined]
3.search()
作用: 检索字符串中的指定值,搜索到就返回出现的位置(从0开始,如果匹配的不只是一个字母,那只会返回第一个字母的位置), 如果搜索失败就返回 -1
用法
stringObject.search(regexp);
//用于检索字符串中指定的字符串或与正则表达式相匹配的字符串,返回匹配的字符串的起始位置的索引,反之返回-1
'abcded'.search(/d/); // 3
4. match()
作用:可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配
用法
stringObject.match(searchvalue)
stringObject.match(regexp)
"abbccbbaab".match(/b+/g); // ["bb", "bb", "b"]
5. replace()
作用:在字符串中用一些字符替换另一些字符或者替换一个与正则表达式匹配的字符串,返回替换后的字符串,原字符串不变
用法
stringObject.replace(string/regexp,string/function)
- 第一个参数:需要匹配的字符串
- 第二个参数:用于替换匹配到的字符串的内容
// 用正则内容/\d\d\d/去匹配字符串12345abcde,将匹配的内容替换成*,并返回替换完成的字符串
'1234abc'.replace(/\d\d\d/g,'*'); // "*4abc"