捕获
(?: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
零宽度正回顾后发断言(js不支持)
(?<=exp)
:断言自身出现的位置的前面能匹配表达式exp
- 匹配前面为name: 结果为wangfei
/(?<=name:)(wangfei)/
零宽度负回顾后发断言(js不支持)
(?<!exp)
:断言此位置的前面不能匹配表达式exp
- 匹配前面不是name:
/(?<!name:)(angelica)/
- 匹配前面不是nick_name:
/(?<!nick_name:)(angelica)/