RegExp 构造函数本身也有几个属性。(在其他语言中,这种属性被称为静态属性。)这些属性适用 于作用域中的所有正则表达式,而且会根据最后执行的正则表达式操作而变化。<br />这些属性还有一个特点,是可以通过两种不同的方式访问它们。换句话说,每个属性都有一个全名和一个简写。下表列出了 RegExp 构造函数的属性。
| 全名 | 简写 | 说明 | 
|---|---|---|
| input | $_ | 最后搜索的字符串(非标准特性) | 
| lastMatch | $& | 最后匹配的文本 | 
| lastParen | $+ | 最后匹配的捕获组(非标准特性) | 
| leftContext | $` | input 字符串中出现在 lastMatch 前面的文本 | 
| rightContext | $’ | input 字符串中出现在 lastMatch 后面的文本 | 
通过这些属性可以提取出与 exec()和 test()执行的操作相关的信息。
举个例子
let text = "this has been a short summer"; 
let pattern = /(.)hort/g; 
if (pattern.test(text)) { 
 console.log(RegExp.input); // this has been a short summer 
 console.log(RegExp.leftContext); // this has been a 
 console.log(RegExp.rightContext); // summer 
 console.log(RegExp.lastMatch); // short 
 console.log(RegExp.lastParen); // s 
}
以上代码创建了一个模式,用于搜索任何后跟”hort”的字符,并把第一个字符放在了捕获组中。 不同属性包含的内容如下。
- input 属性中包含原始的字符串
 - leftConext 属性包含原始字符串中”short”之前的内容,rightContext 属性包含之后的内容
 - lastMath 属性包含匹配的整个正则表达式的上一个字符串,即 “short”
 - lastParen 属性包含捕获组的上一次匹配,即”s”
 
这些属性名也可以替换成简写形式,只不过要使用中括号语法来访问,如下面的例子所示,因为大 多数简写形式都不是合法的 ECMAScript 标识符:
let text = "this has been a short summer"; 
let pattern = /(.)hort/g; 
/* 
 * 注意:Opera 不支持简写属性名
 * IE 不支持多行匹配
 */ 
if (pattern.test(text)) { 
 console.log(RegExp.$_); // this has been a short summer 
 console.log(RegExp["$`"]); // this has been a 
 console.log(RegExp["$'"]); // summer 
 console.log(RegExp["$&"]); // short 
 console.log(RegExp["$+"]); // s 
}
RegExp 还有其他几个构造函数属性,可以存储最多 9 个捕获组的匹配项。这些属性通过 RegExp. $1~RegExp.$9 来访问,分别包含第 1~9 个捕获组的匹配项。在调用 exec()或 test()时,这些属性就会被填充,然后就可以像下面这样使用它们:
let text = "this has been a short summer"; 
let pattern = /(..)or(.)/g; 
if (pattern.test(text)) { 
 console.log(RegExp.$1); // sh 
 console.log(RegExp.$2); // t 
}
在这个例子中,模式包含两个捕获组。调用 test()搜索字符串之后,因为找到了匹配项所以返回 true,而且可以打印出通过 RegExp 构造函数的$1 和$2 属性取得的两个捕获组匹配的内容。
注意
RegExp 构造函数的所有属性都没有任何 Web 标准出处,因此不要在生产环境中使用它们。
