文中所说的前后是有方向的,未免产生歧义,在此声明下 如A => B 我们说B在A的前面,A在B的后面
- A(?=B) 前瞻(Look ahead positive): 匹配的是A,限制条件是A前面是B。
想要匹配abc并且abc的前面是123的表达式,应该这样:
- A(?!B) 负前瞻(Look ahead negative): 顾名思义,该正则匹配A,限制条件是A前面不是B
想要匹配abc并且abc的前面不是123的表达式,应该这样:
- (?<=B)A 后顾(Look behind positive ): 匹配表达式A,限制条件A的后面是B
想要匹配abc并且abc的后面是123的表达式, 尴尬的是js不支持后顾,只支持前瞻,所以用js匹配会这样:
所以我换了sublime编辑器,因为sublime是用python写的,所以会得到这样的结果:
- (?<!B)A 负后顾(Look behind negative ): 匹配表达式A,限制条件是A的后面不是B
想要匹配abc并且abc的后面不是123的表达式,应该这样:
当然,在js中也是不支持负后顾的,不过似乎有提案让js支持后顾,相信过几年js就可以支持后顾了。
本文详细介绍了正则表达式中的前瞻与后顾概念,包括正向前瞻(Lookahead positive)、负向前瞻(Lookahead negative)、正向后顾(Lookbehind positive)及负向后顾(Lookbehind negative),并给出了具体的使用案例。
1170

被折叠的 条评论
为什么被折叠?



