目录
创建正则表达式对象
### 创建正则表达式对象
(1) 字面量方式:var reg = /reg_exp/
(2) 实例化RegExp方式:var re = new RegExp("reg_exp");
### 修饰符
i、g、m、s、U、x、a、D、e
## 修饰符含义:
i:忽略大小写模式
g:全局模式
m:多行匹配模式
s:使"."表示包含换行符
U:不重复匹配
其他省略可以参考以下链接:(4条消息) JavaScript 正则表达式 g、i、m分别代表的含义_js 正则i_qqdoudoua的博客-CSDN博客## 使用
new RegExp(reg_str,修饰符):实例方式
/reg_exp/修饰符:字面量方式
## 示例:
var re = /a/i; # 一个用于匹配a或A的正则对象
正则表达式
### 字符类
[axd]:占位给定样本单个字符
[a-z]:占位连续范围样本单个字符
[^axd]:反占位给定样本单个字符
[^a-z]:反占位连续范围样本单个字符
. :占位任意单个字符
\d:占位单个数字
\D:占位单个非数字
\w:占位[A-Za-z0-9_]范围样本单个字符
\W:占位[^A-Za-z0-9_]范围样本单个字符
\s:占位单个空白符,空格、制表符、换页符、换行符和其他Unicode空格
\S:占位单个非空白符
\t:占位单个制表符
\r:占位单个回车符
\n:占位单个换行符
\v:占位单个垂直制表符
\f:占位单个换页符
### 范围类
x|y:占位匹配x或y
[xyz]:占位具体字符集范围的或匹配
### 量词类
x*:占位任意多个x
x+:占位至少一个x
x?:占位0或1个x
x{n}:占位n个x
x{n,}:占位至少n个x
x{n,m}:占位n~m个x
?:终止量词,给前面提到的量词追加?,来进行匹配终止### 分组类
(x):捕获x到捕获组中,捕获组中的数据索引从1开始递增依次对应
\n:占位引用捕获组数据,n表示要引用的数据在捕获组中的索引
(?<name>x):捕获x到名称为name的捕获组中
### 断言类
## (1) 边界断言
^:断言开始边界
$:断言结束边界
\b:断言单词边界
\B:断言非单词边界
## (2) 跟随判断断言
给匹配加个判断
x(?=y):先行断言,如果有x后面跟着y,那么就匹配这个x
x(?!y):先行否定断言,如果有x后面跟着不是y,那么就匹配这个x
(?<=y)x:后行断言,如果x前面是y,那么就匹配这个x
(?<!y)x:后行否定断言,如果x前面不是y,那么就匹配这个x
### 其他
\:转义符
正则匹配方法
### 前言:
以下中的re_obj代表的是正则对象
### test
检索文本字符串是否匹配,返回bool值
re_obj.test(text_str)
### match
以下两种方式都可以,最终返回匹配结果信息数组:
text_str.match(re_obj);
re_obj[Symbol.match](text_str);
### matchAll
以下两种方式都可以,最终返回匹配结果迭代器:
text_str.matchAll(re_obj); # 注意matchAll使用这种方式要给re_obj后面加/g
re_obj[Symbol.matchAll](text_str);### replace
以下两种方式都可以,最终返回替换匹配的结果字符串:
text_str.replace(re_obj,replace_str);
re_obj[Symbol.replace](text_str,replace_str);### replaceAll
以下两种方式都可以,最终返回替换所有匹配的结果:
text_str.replaceAll(re_obj,replace_str); # 注意replaceAll使用这种方式要给reg_exp后面加/g
re_obj[Symbol.replaceAll](text_str,replace_str);### search
以下两种方式都可以,最终返回第一个匹配成功的索引:
text_str.search(re_obj);
re_obj[Symbol.search]### split
以下两种方式都可以,最终返回以匹配字符分割后的子字符串数组:
text_str.split(re_obj);
re_obj[Symbol.split](text_str);
### exec
匹配正则,返回一个结果数组或 null
re_obj.exec(text_str)