[regex] 正则 零宽断言
捕获
(?:exp)
匹配exp,不捕获匹配的文本,也不给此分组分配组号。
- 零宽断言不占用位置,也就是说,匹配结果里是不会返回它的。
零宽度正预测先行断言
(?=exp)
:断言自身出现的位置的后面能匹配表达式exp。
- 匹配后面为_path,结果为product
/(product)(?=_path)/.test('product_path') //true
- 会匹配除字符除末尾所有的位置
(?=[^$])
- 会匹配连续的三个数字,并且这三个数字不能在字符串的末尾
/(\d{3})(?=[^$])/
- 至少出现一次 p r o
/^(?=.*p)(?=.*r)(?=.*o)\w+$/.test('product_path')
零宽度负预测先行断言
(?!exp)
:断言此位置的后面不能匹配表达式exp。
- 匹配后面不是_path
/(product)(?!_path)/.test('product_path') //false
- 匹配后面不是_url
/(product)(?!_url)/.test('product_path') //true
- 一个例子
这里匹配的是,[后面不能为a或b
let t = /\[(?!a)(?!b)[a-z]3\]/;
console.info(t.test('[3a]'))//false
console.info(t.test('[a3]'))//false
console.info(t.test('[b3]'))//false
console.info(t.test('[c3]'))//true
console.info(t.test('[33]'))//false
零宽度正回顾后发断言(ES2018开始才支持)
(?<=exp)
:断言自身出现的位置的前面能匹配表达式exp
`'Benjamin Franklin is on the $100 €90 bill'.match(/(?<=\$)\d+/g) `
//["100"]
- 匹配前面为name: 结果为wangfei
/(?<=name:)(wangfei)/
零宽度负回顾后发断言(ES2018开始才支持)
(?<!exp)
:断言此位置的前面不能匹配表达式exp
`'it’s is worth about €90 $100'.match(/(?<!\$)\d+/g)`
//["90", "00"]
- 匹配前面不是name:
/(?<!name:)(angelica)/
- 匹配前面不是nick_name:
/(?<!nick_name:)(angelica)/