一、简介
-
Regular Expressions
正则表达式
二、使用
2.1 开始结束
-
^
caret
脱字符
,表文本开始位置,作为匹配文本开始元字符的时候必须是正则主主体的第一个字符,否则无效
console.log('hello'.match(/^h/))
//[ 'h', index: 0, input: 'hello' ]
console.log('hello'.match(/llo$/))
//[ 'llo', index: 2, input: 'hello' ]
2.2 转义
console.log('$100.00'.match(/\$/))
//[ '$', index: 0, input: '$100.00' ]
元字符 |
含义 |
\b |
匹配一个单词边界(boundary) |
\B |
匹配一个非单词边界 |
\d |
匹配一个数字字符(digit) |
\D |
匹配一个非数字字符 |
\s |
匹配一个空白字符(space) |
\S |
匹配一个非空白字符 |
\w |
匹配一个字母或者一个数字或者一个下划线(word) |
\W |
匹配一个字母、数字和下划线之外的字符 |
\b
如^
等一样匹配的仅仅是一个位置,一般单词和空格之间的位置,或者首行单词开始前的位置,对中文无效
\d
匹配的代表数字的字符
\s
匹配空白字符,一般指空格\f\n\r\t\v
总和(换页、换行、回车、水平制表、垂直制表符)
当大小写组合,匹配任何字符
.
匹配换行符之外的任意单个字符
console.debug('Hello world!'.match(/\b/))
//[ '', index: 0, input: 'Hello world!' ]
console.debug('Hello world!'.match(/\bH/))
//[ 'H', index: 0, input: 'Hello world!' ]
console.log('Hello world!'.match(/./))
//[ 'H', index: 0, input: 'Hello world!' ]
console.log('Hello world!'.match(/[\s\S]/))
//[ 'H', index: 0, input: 'Hello world!' ]
2.3 量词
量词 |
含义 |
? |
重复零次或者一次 |
+ |
重复一次或者多次,也就是至少一次 |
* |
重复零次或者多次,也就是任意次数 |
{n} |
重复n次 |
{n,} |
重复n次或者更多次 |
{n,m} |
重复n次到m次之间的次数,包含n次和m次 |
console.log('goods'.match(/go+ds/))
//[ 'goods', index: 0, input: 'goods' ]
console.log('goods'.match(/go{1,2}ds/))
//[ 'goods', index: 0, input: 'goods' ]
2.4 字符组
- 匹配符合字符组规则的一个字符
- 字符组中元字符不需要转义
-
^
字符组中表取反
-
-
字符组中表连字符
console.log('goods'.match(/[0-z]/))
//[ 'g', index: 0, input: 'goods' ]
console.log('goods'.match(/[^goo]/))
//[ 'd', index: 3, input: 'goods' ]
console.log('$goods'.match(/[$&@]/))
//[ '$', index: 0, input: '$goods' ]
2.5 捕获组
console.log('very very very good'.match(/(very )+good/))
//[ 'very very very good',
// 'very ',
// index: 0,
// input: 'very very very good' ]
console.log('very very$ very good'.match(/(very[$]?[\s])+good/))
//[ 'very very$ very good',
// 'very ',
// index: 0,
// input: 'very very$ very good' ]
2.6 分支
console.log('goods'.match(/(g|o)+/))
//[ 'goo', 'o', index: 0, input: 'goods' ]