文中所说的前后是有方向的,未免产生歧义,在此声明下
如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就可以支持后顾了。
前面文章讲解了一些正则表达式的文章,今天讲讲?=,?:和?!这几个符号的作用吧~
这几个符号用的不多,主要解释如下:
前瞻:
haorooms(?=hrms) 查找hrms前面的haorooms,表示我们需要匹配hrms的前面
后顾:
(?<=hrms)haorooms 查找hrms后面的haorooms
负前瞻:
haorooms(?!hrms) 查找后面不是hrms的haorooms,
负后顾:
(?<!=hrms)haorooms 查找前面不是hrms的haorooms