正则: 一种字符串匹配的模式
元字符:[][^]?*+{min,max} ^ $ () \1\2 |
普通字符: 包括没有显式指定为元字符的所有可打印和不可打印字符。这包括所有大写和小写字母、所有数字、所有标点符号和一些其他符号。
字符组[]
/a/.test('a')
/[abc]/.test('a') 分组[]
/[a-z]/.test('a') 分组范围-
/[^a-z]/.test('a') 范围取反^
简写 | {m,n}等效形式 | 描述 |
---|---|---|
\d | [0-9] | 代表一个数字 |
\D | [^0-9] | 代表非数字 |
\s | 代表换行符、Tab制表符等空白字符。 | |
\S | 代表非空白字符。 | |
\w | [0-9A-Za-z_] | 匹配字母或数字或下划线或汉字,即能组成单词的字符。 |
\W | [^\w] 或 [^0-9A-Za-z_] | 非\w |
量词{}
/\d{6}/.test('565532') true
/\d{6}/.exec('565532') 0:565532
范围浮动(不要加空格) {min,max} {min,}
/\d{2,6}/.exec('565532')
简写 | {m,n}等效形式 | 描述 | 贪婪模式 | 非贪婪模式? |
---|---|---|---|---|
+ | {1,} | 出现次数大于等于1 | /a+/.exec('aaaaaaaa') //aaaaaaaa | /a+?/.exec('aaaaaaaa') //a |
* | {0,} | 出现次数大于等于0 | /a*/.exec('aaaaaaaa') //aaaaaaaa | /a*?/.exec('aaaaaaaa') //"" |
? | {0,1} | 出现次数为0或者1 | /a?/.exec('aaaaaaaa') //a | /.exec('aaaaaaaa') //"" |
贪婪模式:能多就多
非贪婪模式:能少就少 ,在量词+ ? * {1,} {0,} {0,1} 后面加 ?
分组 ()
1.分组,也叫子表达式
- 引用, 可以捕获子表达式
/(ab){2}/.exec('abab')
/(\d{4}-\d{1,2}-\d{1,2}/.exec('2021-2-17')
/(\d{4})-(\d{1,2})-(\d{1,2})/.exec('2021-2-17')[1]
RegExp.$1
正则mdn
- 反向引用 先括起来 ,再用\1
/([a-z])\1/.exec('bb') 匹配相同两个字符
/<([^<>]+)>[\w\W]?</\1>/.exec('<h1><h1>123</h1></h1>')
/<([^<>]+)>[\w\W]</\1>/.exec('<h1><h1>123</h1></h1>') 匹配标签 <h1> - 非捕获 ?: 不补获子表达式
/(abc){2}/.exec('abcabc'); RegExp.$1 //abc
/(?:abc){2}/.exec('abcabc'); RegExp.$1 //""
分支 |
选择或者关系; 单独整体,自左向右,一旦匹配上不回头
/12|23|56/.exec('1') //null
/12|23|56/.exec('12') //12
eg. ip 192.168.1.1
//0-255
个 \d[0-9]
十 [1-9]\d 10-99
百 1\d\d 100-199
2[0-4]\d 200-249
25[0-5] 250-255
\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5] // 250->2 一旦匹配上不回
25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d[0-9] //反过来就可以
/25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d[0-9]/.exec('255')
月1-12 [1-9]|1[0-2]
日1-31 [1-9]|2\d|3[01]
时 0-24 \d|1\d|2[0-4]
分 0-60 \d|[1-5]\d|60
秒 0-60 \d|[1-5]\d|60
断言
文本是否在文字边界 \b \B
/\ban\b/.test('an apple') //true
/\ban\b/.test('anapple') //false
/^an/.test('anapple') //以an开头
/le$/.test('anapple') //以le结尾
环视
紧跟b的a
/a(?=b)/.exec('ab') //a
/a(?!b)/.exec('ab') //null
/a(?!b)/.exec('ac') //a
匹配模式
全局匹配 g 忽略大小写 i 多行匹配 m
/a/g.exec('anaple')
'anaple'.replace(/a/,'b') //bnaple
'anaple'.replace(/a/g,'b') //bnbple
/a/i.exec('Ab') //A
/a/m.exec('c\nab') //a
/world$/m.test('hello world\n')
优先级
运算符 | 描述 |
---|---|
\ | 转义符 |
(), (?:), (?=), [] | 圆括号和方括号 |
*, +, ?, {n}, {n,}, {n,m} | 限定符 |
^, $, \ | 任何元字符、任何字符 定位点和序列(即:位置和顺序) |
替换,"或"操作字符具有高于替换运算符的优先级,使得"m|food"匹配"m"或"food"。若要匹配"mood"或"food",请使用括号创建子表达式,从而产生"(m|f)ood"。 |