一. 正则表达式规则
符号 | 描述 |
---|
() | 标记一个子表达式的开始和结尾位置,要匹配(、),前面加转义字符 \ |
[] | 标记一个中括号表达式的开始和结束,要匹配[、],前面加转义字符 \ |
[字符集] | 比配单个字符 |
{n} | n 是一个非负整数。匹配确定的 n 次 |
{n,m} | m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次 |
+ | 匹配前面的子表达式一次或多次 |
* | 匹配前面的子表达式零次或多次 |
? | 匹配前面的子表达式零次或一次,或指明一个非贪婪限定符 |
\ | 将下一个字符标记为或特殊字符、或原义字符、或向后引用、或八进制转义符 |
^ | 匹配输入字符串的开始位置 |
$ | 匹配输入字符串的结束位置 |
| | 指明两项中的一个选择,相当于或,要匹配|,字符前加\ |
1.1 正则表达式修饰符
修饰符 | 描述 |
---|
i | 执行对大小写不敏感的匹配 |
g | 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止) |
m | 执行多行匹配 |
1.2 例子
规则 | 描述 |
---|
[a-z] | 匹配a-z中一个字符 |
^ [0-9]ac{2}$ | 匹配0-9某一个数字开始且acc结尾的一个字符 |
[0-9]* | 匹配0-9中零个或者多个数字 |
[0-9]+ | 匹配0-9中一个或者多个数字 |
^ [1-9] | 匹配1-9某一个数字开头的 |
abc$ | 匹配以abc结尾 |
do(a)? | 匹配是否包含do或者doa |
let rule = /^[0-9]abc$/
let n1 = '123abc'
let n2 = '1abc'
let n3 = 'abc'
console.log(n1.match(rule))
console.log(n2.match(rule))
console.log(n3.match(rule))
二. 正则表达式方法
- test(): 用于检测一个字符串是否匹配某个模式,如果字符串中含有匹配的文本,则返回 true,否则返回 false
- exec(): 该函数返回一个数组,其中存放匹配的结果。如果未找到匹配,则返回值为 null。
三. 字符串的方法参数是正则表达式
- search(x) : x表示字符串或者正则表达式,满足条件返回第一次出现的下标,找不到返回-1。
- replace(x,str): x表示字符串或者正则表达式,str替换成字符串,返回替换过后新的字符串。
- match(x): x表示字符串或者正则表达式,满足条件返回数组,找不到返回null。
四. 判断是否包含某些字符
例子:判断字符串中是否包含[]【】字符
let regular1 = /\[|\]|\【|\】/
let str1 = 'ass[22'
let str2 = 'ass【】1'
let str3 = ']ass2'
let str4 = '233ass'
let status1 = regular1.test(str1)
let status2 = regular1.test(str2)
let status3 = regular1.test(str3)
let status4 = regular1.test(str4)
五. 提取满足一定规则的数据
例子:获取字符串中的满足规则的数据
let regular1 = /[0-9]+/
let regular2 = /[0-9]+/g
let regular3 = /[A-Z]+/gi
let str1 = '234a1'
let status1 = regular1.exec(str1)
console.log(status1)
let status2 = str1.match(regular1)
console.log(status2)
let status3 = str1.match(regular2)
console.log(status3)
let status4 = str1.match(regular3)
console.log(status4)