正则表达式
一、正则表达式的创建以及其中变量的使用
-
js 提供了字面量与对象两种方式创建正则表达式
字面量创建:使用/ 正则 /,双斜杠的形式来创建正则表达式
对象创建:let reg=new RegExp(va) 可以接受一个 va 变量作为参数 -
创建正则使用变量
一般情况下如果使用变量,会用对象的方式来创建变量
如果在自面量中使用变量可以采用 js 的 eval 方法 (eval(string) eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码)
举例
let va=‘a’; let text=‘abc’
eval(/${va}/
).test(text);
二、正则的符号
符号 | 含义 | 举例 |
---|---|---|
| (选择修饰符) | 就是 | 左右两侧有一个匹配到就可以 | |
\ (字符转义符) | 转义用于改变字符的含义,用来对某个字符有多种语义时的处理。 | |
边界符++ | ||
^ | 匹配字符串的开始 | |
$ | 匹配字符串的结束,忽略换行符 | |
元字符++ | ||
\d | 匹配任意一个数字 | [0-9] |
\D | 与除了数字以外的任何一个字符匹配 | [^0-9] |
\w | 与任意一个英文字母,数字或下划线匹配 | [A-Za-z0-9_] |
\s | 任意一个空白字符匹配,如空格,制表符\t ,换行符\n | [\n\f\r\t\v] |
\S | 除了空白符外任意一个字符匹配 | [^\n\f\r\t\v] |
. | 匹配除换行符外的任意字符 | |
模式修饰符++ | ||
i | 不区分大小写字母的匹配 | /abc/i |
g | 全局搜索所有匹配内容 | |
m | 视为多行 | |
s | 视为单行忽略换行符,使用. 可以匹配所有字符 | |
y | 从 regexp.lastIndex 开始匹配 | |
u | 正确处理四个字符的 UTF-16 编码 | |
原子表++ | ||
[] | 只匹配其中的一个原子 | |
[^] | 只匹配"除了"其中字符的任意一个原子 | |
[0-9] | 匹配 0-9 任何一个数字 | |
[a-z] | 匹配小写 a-z 任何一个字母 | |
[A-Z] | 匹配大写 A-Z 任何一个字母 | |
重复匹配++ | ||
* | 重复零次或更多次 | |
+ | 重复一次或更多次 | |
? | 重复零次或一次 | |
{n} | 重复 n 次 | |
{n,} | 重复 n 次或更多次 | |
{n,m} | 重复 n 到 m 次 | |
禁止贪婪++ | ||
*? | 重复任意次,但尽可能少重复 | |
+? | 重复 1 次或更多次,但尽可能少重复 | |
?? | 重复 0 次或 1 次,但尽可能少重复 | |
{n,m}? | 重复 n 到 m 次,但尽可能少重复 | |
{n,}? | 重复 n 次以上,但尽可能少重复 |