1. RegExp 构造函数本身也有几个属性。(在其他语言中,这种属性被称为静态属性。)这些属性适用 于作用域中的所有正则表达式,而且会根据最后执行的正则表达式操作而变化。<br />这些属性还有一个特点,是可以通过两种不同的方式访问它们。换句话说,每个属性都有一个全名和一个简写。下表列出了 RegExp 构造函数的属性。
全名 简写 说明
input $_ 最后搜索的字符串(非标准特性)
lastMatch $& 最后匹配的文本
lastParen $+ 最后匹配的捕获组(非标准特性)
leftContext $` input 字符串中出现在 lastMatch 前面的文本
rightContext $’ input 字符串中出现在 lastMatch 后面的文本

通过这些属性可以提取出与 exec()和 test()执行的操作相关的信息。
举个例子

  1. let text = "this has been a short summer";
  2. let pattern = /(.)hort/g;
  3. if (pattern.test(text)) {
  4. console.log(RegExp.input); // this has been a short summer
  5. console.log(RegExp.leftContext); // this has been a
  6. console.log(RegExp.rightContext); // summer
  7. console.log(RegExp.lastMatch); // short
  8. console.log(RegExp.lastParen); // s
  9. }

以上代码创建了一个模式,用于搜索任何后跟”hort”的字符,并把第一个字符放在了捕获组中。 不同属性包含的内容如下。

  • input 属性中包含原始的字符串
  • leftConext 属性包含原始字符串中”short”之前的内容,rightContext 属性包含之后的内容
  • lastMath 属性包含匹配的整个正则表达式的上一个字符串,即 “short”
  • lastParen 属性包含捕获组的上一次匹配,即”s”

这些属性名也可以替换成简写形式,只不过要使用中括号语法来访问,如下面的例子所示,因为大 多数简写形式都不是合法的 ECMAScript 标识符:

  1. let text = "this has been a short summer";
  2. let pattern = /(.)hort/g;
  3. /*
  4. * 注意:Opera 不支持简写属性名
  5. * IE 不支持多行匹配
  6. */
  7. if (pattern.test(text)) {
  8. console.log(RegExp.$_); // this has been a short summer
  9. console.log(RegExp["$`"]); // this has been a
  10. console.log(RegExp["$'"]); // summer
  11. console.log(RegExp["$&"]); // short
  12. console.log(RegExp["$+"]); // s
  13. }

RegExp 还有其他几个构造函数属性,可以存储最多 9 个捕获组的匹配项。这些属性通过 RegExp. $1~RegExp.$9 来访问,分别包含第 1~9 个捕获组的匹配项。在调用 exec()或 test()时,这些属性就会被填充,然后就可以像下面这样使用它们:

  1. let text = "this has been a short summer";
  2. let pattern = /(..)or(.)/g;
  3. if (pattern.test(text)) {
  4. console.log(RegExp.$1); // sh
  5. console.log(RegExp.$2); // t
  6. }

在这个例子中,模式包含两个捕获组。调用 test()搜索字符串之后,因为找到了匹配项所以返回 true,而且可以打印出通过 RegExp 构造函数的$1 和$2 属性取得的两个捕获组匹配的内容。

注意

RegExp 构造函数的所有属性都没有任何 Web 标准出处,因此不要在生产环境中使用它们。