文中所說的前后是有方向的,未免產(chǎn)生歧義,在此聲明下
如A => B
我們說B在A的前面,A在B的后面
- A(?=B)
前瞻(Look ahead positive): 匹配的是A,限制條件是A前面是B。
想要匹配abc并且abc的前面是123的表達(dá)式,應(yīng)該這樣:

- A(?!B)
負(fù)前瞻(Look ahead negative): 顧名思義,該正則匹配A,限制條件是A前面不是B
想要匹配abc并且abc的前面不是123的表達(dá)式,應(yīng)該這樣:

- (?<=B)A
后顧(Look behind positive ): 匹配表達(dá)式A,限制條件A的后面是B
想要匹配abc并且abc的后面是123的表達(dá)式, 尷尬的是js不支持后顧,只支持前瞻,所以用js匹配會(huì)這樣:

所以我換了sublime編輯器,因?yàn)?code>sublime是用python寫的,所以會(huì)得到這樣的結(jié)果:

- (?<!B)A
負(fù)后顧(Look behind negative ): 匹配表達(dá)式A,限制條件是A的后面不是B
想要匹配abc并且abc的后面不是123的表達(dá)式,應(yīng)該這樣:

當(dāng)然,在js中也是不支持負(fù)后顧的,不過似乎有提案讓js支持后顧,相信過幾年js就可以支持后顧了。