Hello! 欢迎来到小浪资源网!


正则表达式环视、断言和预查:它们的位置和用法有何区别?


正则表达式环视、断言和预查:它们的位置和用法有何区别?

正则表达式的环视、断言和预查位置

在讨论正则表达式中环视、断言和预查的位置时,需要首先理解它们的不同含义和用法。

正向预查

正向预查使用 (?=…) 语法,它匹配一个字符串,其后紧跟某个模式。通常情况下,正向预查会被放置在匹配字符串的后面,以确保在该模式之前存在所需的序列。

反向预查

反向预查使用 (?

然而,在特定情况下,可以将正向预查放置在匹配字符串的前面,而反向预查放置在匹配字符串的后面。这通常用于否定或排除特定模式的匹配。

理解预查位置

针对你提出的困惑,^(?!baidu).*$ 和 ^(?

  • ^(?!baidu).*$ 匹配开头字符串(空字符串),后面不跟着 baidu,然后再匹配任意字符串。
  • ^(?

第二种表达式没有意义,因为字符串既然在开头,那之前一定没有 baidu。因此,这个表达式始终为真。

要排除 baidu 开头的字符串,可以使用部分匹配的函数来判断,例如:

/^(?!baidu)/.test('baidu.com'); // false /^(?!baidu)/.test('www.baidu.com'); // true

而反向预查通常用于断言在字符位置之后被匹配的模式,而不是排除模式的存在。

相关阅读