正则表达式中有前瞻(Lookahead)和后顾(Lookbehind)的概念,需要注意一点,正则表达式中的前和后和我们一般理解的前后有点不同。一段文本,我们一般习惯把文本开头的方向称作“前面”,文本末尾方向称为“后面”。但是对于正则表达式引擎来说,因为它是从文本头部向尾部开始解析的(可以通过正则选项控制解析方向),因此对于文本尾部方向,称为“前”,因为这个时候,正则引擎还没走到那块,而对文本头部方向,则称为“后”,因为正则引擎已经走过了那一块地方。如下图所示:
// 前瞻:
exp1(?=exp2) 查找exp2前面的exp1
// 后顾:
(?<=exp2)exp1 查找exp2后面的exp1
// 负前瞻:
exp1(?!exp2) 查找后面不是exp2的exp1
// 负后顾:
(?<!exp2)exp1 查找前面不是exp2的exp1
————————————————
匹配不包含特定字符串的正则
/^(?!.*xx).*$/g //xx代表特定字符串
匹配不以特定字符串开头的正则
/^(?!xx).*?$/g //xx代表特定字符串
. 匹配任意除换行符“\n”外的字符;
*表示匹配前一个字符0次或无限次;
?代表的是非贪婪模式; 若不写?为贪婪模式
.*连接在一起是取尽量多的任意字符 .*?连接在一起时取尽量少的任意字符