正则表达式是 regular expression ,看来英文比中文要好理解多了,就是检查表达式符
不符合规定!!正则表达式有一个功能十分强大而又十分复杂的对象 RegExp ,在 Javascript1.2 版本以

上提供。

下面我们看看有关正则表达式的介绍:

正则表达式对象用来规范一个规范的表达式 ( 也就是表达式符不符合特定的要求,比如是不是
Email
地址格式等 ) ,它具有用来检查给出的字符串是否符合规则的属性和方法。

除此之外,你用 RegExp 构造器建立的个别正则表达式对象的属性,就已经预先定义好了正则表达式

对象的静态属性,你可以随时使用它们。

核心对象:

Javascript 1.2, NES 3.0 以上版本提供。

Javascript 1.3 以后版本增加了 toSource 方法。

建立方法:

文字格式或 RegExp 构造器函数。

文字建立格式使用以下格式:

/pattern/flags
/ 模式 / 标记

构造器函数方法使用方法如下:
new RegExp("pattern"[, "flags"])
new RegExp(" 模式 "[," 标记 "])

参数:
pattern(
模式
)
表示正则表达式的文本

flags( 标记 )
如果指定此项, flags 可以是下面值之一:

g: global match(
全定匹配
)
i: ignore case(
忽略大小写
)
gi: both global match and ignore case(
匹配所有可能的值,也忽略大小写 )

注意:文本格式中的参数不要使用引号标记,而构造器函数的参数则要使用引号标记。所以下面的
表达式建立同样的正则表达式:

/ab+c/i
   new RegExp("ab+c", "i")

描述:
当使用构造函数的时候,必须使用正常的字符串避开规则 ( 在字符串中加入前导字符 \ ) 是必须的。

例如,下面的两条语句是等价的:

re = new RegExp("
\\w +")
re = /\w+/

下面的提供了在正则表达式中能够使用的完整对特殊字符的一个完整的列表和描述。

1.3 :正则表达式中的特殊字符:

字符 \
意义:对于字符,通常表示按字面意义,指出接着的字符为特殊字符, \ 不作解释。

例如: /b/ 匹配字符 'b', 通过在 b 前面加一个反斜杠 \ ,也就是 /\b/ ,则该字符变成特殊字符,表示

匹配一个单词的分界线。

或者:
 
对于几个字符,通常说明是特殊的,指出紧接着的字符不是特殊的,而应该按字面解释。

例如: * 是一个特殊字符,匹配任意个字符 ( 包括 0 个字符 ) ;例如: /a*/ 意味匹配 0 个或多个 a

为了匹配字面上的 * ,在 a 前面加一个反斜杠;例如: /a\*/ 匹配 'a*'

字符 ^
意义:表示匹配的字符必须在最前边。

例如: /^A/ 不匹配 "an A," 中的 'A' ,但匹配 "An A." 中最前面的 'A'

字符 $
意义:与 ^ 类似,匹配最末的字符。

例如: /t$/ 不匹配 "eater" 中的 't' ,但匹配 "eat" 中的 't'

字符 *
意义:匹配 * 前面的字符 0 次或 n 次。

例如 :/bo*/ 匹配 "A ghost booooed" 中的 'boooo' "A bird warbled" 中的 'b' ,但不匹配
"A goat g
runted"
中的任何字符。

字符 +
意义:匹配 + 号前面的字符 1 次或 n 次。等价于 {1,}

例如: /a+/ 匹配 "candy" 中的 'a' "caaaaaaandy." 中的所有 'a'

字符 ?
意义:匹配 ? 前面的字符 0 次或 1 次。

例如: /e?le?/ 匹配 "angel" 中的 'el' "angle." 中的 'le'

字符 .
意义: ( 小数点 ) 匹配除换行符外的所有单个的字符。

例如: /.n/ 匹配 "nay, an apple is on the tree" 中的 'an' 'on' ,但不匹配 'nay'


字符 (x)
意义:匹配 'x' 并记录匹配的值。

例如: /(foo)/ 匹配和记录 "foo bar." 中的 'foo' 。匹配子串能被结果数组中的素 [1], ..., [n]

回,或被 RegExp 对象的属性 $1, ..., $9 返回。

字符 x|y
意义:匹配 'x' 或者 'y'

例如: /green|red/ 匹配 "green apple" 中的 'green' "red apple." 中的 'red'

字符 {n}
意义:这里的 n 是一个正整数。匹配前面的 n 个字符。

例如: /a{2}/ 不匹配 "candy," 中的 'a' ,但匹配 "caandy," 中的所有 'a' "caaandy." 中前面的两个

'a'

字符 {n,}
意义:这里的 n 是一个正整数。匹配至少 n 个前面的字符。

例如: /a{2,} 不匹配 "candy" 中的 'a' ,但匹配 "caandy" 中的所有 'a' "caaaaaaandy." 中的所有 'a'

字符 {n,m}
意义:这里的 n m 都是正整数。匹配至少 n 个最多 m 个前面的字符。

例如: /a{1,3}/ 不匹配 "cndy" 中的任何字符,但匹配 "candy," 中的 'a' "caandy," 中的前面两个

'a'
"caaaaaaandy" 中前面的三个 'a' ,注意:即使 "caaaaaaandy" 中有很多个 'a' ,但只匹配前面的三

'a' "aaa"

字符 [xyz]
意义:一字符列表,匹配列出中的任一字符。你可以通过连字符 - 指出一个字符范围。

例如: [abcd] [a-c] 一样。它们匹配 "brisket" 中的 'b' "ache" 中的 'c'

字符 [^xyz]
意义:一字符补集,也就是说,它匹配除了列出的字符外的所有东西。 你可以使用连字符 - 指出一

字符范围。

例如: [^abc] [^a-c] 等价,它们最早匹配 "brisket" 中的 'r' "chop." 中的 'h'

字符 [\b]
意义:匹配一个空格 ( 不要与 \b 混淆 )

字符 \b
意义:匹配一个单词的分界线,比如一个空格 ( 不要与 [\b] 混淆
)
例如: /\bn\w/ 匹配 "noonday" 中的 'no' /\wy\b/ 匹配 "possibly yesterday." 中的 'ly'

字符 \B
意义:匹配一个单词的非分界线

例如: /\w\Bn/ 匹配 "noonday" 中的 'on' /y\B\w/ 匹配 "possibly yesterday." 中的 'ye'

字符 \cX
意义:这里的 X 是一个控制字符。匹配一个字符串的控制字符。

例如: /\cM/ 匹配一个字符串中的 control-M

字符 \d
意义:匹配一个数字,等价于 [0-9]

例如: /\d/ /[0-9]/ 匹配 "B2 is the suite number." 中的 '2'

字符 \D
意义:匹配任何的非数字,等价于 [^0-9]

例如: /\D/ /[^0-9]/ 匹配 "B2 is the suite number." 中的 'B'

字符 \f
意义:匹配一个表单符

字符 \n
意义:匹配一个换行符

字符 \r
意义:匹配一个回车符

字符 \s
意义:匹配一个单个 white 空格符,包括空格, tab form feed ,换行符,等价于 [ \f\n\r\t\v]

例如: /\s\w*/ 匹配 "foo bar." 中的 ' bar'

字符 \S
意义:匹配除 white 空格符以外的一个单个的字符,等价于 [^ \f\n\r\t\v]

例如: /\S/\w* 匹配 "foo bar." 中的 'foo'

字符 \t
意义:匹配一个制表符

字符 \v
意义:匹配一个顶头制表符

字符 \w
意义:匹配所有的数字和字母以及下划线,等价于 [A-Za-z0-9_]

例如: /\w/ 匹配 "apple," 中的 'a' "$5.28," 中的 '5' "3D." 中的 '3'

字符 \W 
意义:匹配除数字、字母外及下划线外的其它字符,等价于 [^A-Za-z0-9_]

例如: /\W/ 或者 /[^$A-Za-z0-9_]/ 匹配 "50%." 中的 '%'

字符 \n
意义:这里的 n 是一个正整数。匹配一个正则表达式的最后一个子串的 n 的值 ( 计数左圆括号 )

例如: /apple(,)\sorange\1/ 匹配 "apple, orange, cherry, peach." 中的 'apple, orange' ,下面
有一个更加完整的例子。

注意:如果左圆括号中的数字比 \n 指定的数字还小,则 \n 取下一行的八进制 escape 作为描述。

字符 \ooctal \xhex
意义:这里的 \ooctal 是一个八进制的 escape 值,而 \xhex 是一个十六进制的 escape 值,允许在一个

正则表达式中嵌入 ASCII 码。


当表达式被检查的时候,文字符号提供了编辑正则表达式的方法。利用文字符号可以使到正则表达
式保持为常数。例如,如果你在一个循环中使用文字符号来构造一个正则表达式,正则表达式不需进行

反复编译。

正则表达式对象构造器,例如, new RegExp("ab+c") ,提供正则表达式的运行时编译。当你知道正

则表达式的模式会变化的时候,应该使用构造函数,或者你不知道正则表达式的模式,而它们是从另外

的源获得的时候,比如由用户输入时。一旦你定义好了正则表达式,该正则表达式可在任何地方使用,

并且可以改变,你可以使用编译方法来编译一个新的正则表达式以便重新使用。

一个分离预先定义的 RegExp 对象可以在每个窗口中使用;也就是说,每个分离的 Javascript 线程运

行以获得自己的 RegExp 对象。因为每个脚本在一个线程中是不可中断的,这就确保了不同的脚本不会覆

RegExp 对象的值。

预定义的 RegExp 对象包含的静态属性:
input, multiline, lastMatch,lastParen, leftContext, 
rightContext,
以及从 $1 $9 input multiline 属性能被预设。其它静态属性的值是在执行个别正则

表达式对象的 exec test 方法后,且在执行字符串的 match replace 方法后设置的。

属性
注意 RegExp 对象的几个属性既有长名字又有短名字 ( Perl) 。这些名字都是指向相同的值。 Perl

一种编程语言,而 Javascript 模仿了它的正则表达式。

属性 $1, ..., $9
取得匹配的子串,如果有的话

属性 $_
参考 input

属性 $*
参考 multiline

属性 $&
参考 lastMatch

属性 $+
参考 lastParen

属性 $`
参考 leftContext

属性 $'
参考 rightContext

属性 constructor
指定用来建立对象原型函

属性 global
决定是否测试正则表达式是否不能匹配所有的字符串,或者只是与最先的冲突。

属性 ignoreCase
决定试图匹配字符串的时候是否忽略大小写

属性 input
当正则表达式被匹配的时候,为相反的字符串。

属性 lastIndex
决定下一次匹配从那里开始

属性 lastMatch
最后一个匹配的字符

属性 lastParen
子串匹配的时候,最后一个 parenthesized ,如果有的话。

属性 leftContext
最近一次匹配前的子串。

属性 multiline
是否在串的多行中搜索。

属性 prototype
允许附加属性到所有的对象

属性 rightContext
最近一次匹配后的的子串。

属性 source
模式文本

 

 

方法
compile
方法

编译一个正则表达式对象

exec 方法
运行正则表达式匹配

test 方法
测试正则达式匹配

toSource 方法
返回一个对象的文字描述指定的对象;你可以使用这个值来建立一个新的对象。不考虑
Object.toS
ource
方法。

toString 方法
返回一个字符串描述指定的对象,不考虑 Object.toString 对象。

valueOf 方法
返回指定对角的原始值。不考虑 Object.valueOf 方法。

 另外,这个对象继承了对象的 watch unwatch 方法

 

  例子:
  例1、下述示例脚本使用 replace 方法来转换串中的单词。在替换的文本中,脚本使用全局
RegExp
对象的 $1 $2 属性的值。注意,在作为第二个参数传递给 replace 方法的时候, RegExp 对象的 $ 属性的名

称。

<script LANGUAGE="Javascript1.2">
re = /(\w+)\s(\w+)/;
str = "John Smith";
newstr=str.replace(re,"$2, $1");
document.write(newstr)
</script>
显示结果: "Smith, John". 

  例2、下述示例脚本中, RegExp.input Change 事件处理句柄设置。在 getInfo 函数中, exec 方法
使用 RegExp.input 的值作为它的参数,注意 RegExp 预置了 $ 属性。


<script LANGUAGE="Javascript1.2">
function getInfo(abc)
{
re = /(\w+)\s(\d+)/;
re.exec(abc.value);
window.alert(RegExp.$1 + ", your age is " + RegExp.$2);
}
</script>

  请输入你的姓和年龄,输入完后按回车键。
  
<FORM><INPUT TYPE="TEXT" NAME="NameAge" onChange="getInfo(this);"></FORM>
   </HTML>


$1, ..., $9
属性
用圆括号括着的匹配子串,如果有的话。

RegExp 的属性

静态,只读

Javascript 1.2, NES 3.0 以上版本提供
描述:因为 input 是静态属性,不是个别正则表达式对象的属性。你可以使用 RegExp.input 访问该

属性。

能加上圆括号的子串的数量不受限制,但正则表达式对象只能保留最后 9 条。如果你要访问所有的
圆括号内的匹配字串,你可以使用返回的数组。

这些属性能用在 RegExp.replace 方法替换后的字符串 ( 输出结果 ) 。当使用这种方式的时候,不用预
先考虑 RegExp 对象。下面给出例子。当正则表达式中没有包含圆括号的时候,该脚本解释成 $n 的字面意

义。 ( 这里的 n 是一个正整数 )


例如:
下例脚本使用 replace 方法来交换串中单词的位置。在替换后的文本字串中,脚本使用正则表达式

RegExp
对象的 $1 $2 属性的值。注意:当它们向 replace 方法传递参数的时候,这里没有考虑 $ 属性的

RegExp
对象的名称。

<script LANGUAGE="Javascript1.2">
re = /(\w+)\s(\w+)/;
str = "John Smith";
newstr=str.replace(re,"$2, $1");
document.write(newstr)
</script>
显示的输出结果为: Smith, John

 
正则表达式详述(二)  

以下这些不是正则表达式的新增对象请参阅对应的 Javascript 对象的属性 $_ 属性 参考 input $* 属性
参考 multiline $& 属性 参考 lastMatch $+ 属性 参考 lastParen $` 属性

参考 leftContext $' 属性 参考 rightContext compile 方法 在脚本运行期间编译正则表达式对象

属于 RegExp 的方法 Javascript 1.2, NES 3.0 以上版本提供 语法:

regexp.compile(pattern[, flags])
以数: regexp 正则表达式的名称,可以是变量名或文字串。
 
pattern
正则表达式的定义文本。 flags 如果指定的话,可以是下面其中的一个: "g": 匹配所有可能的字串

"i":
忽略大小写 "gi": 匹配所有可能的字串及忽略大小写 描述:

使用 compile 方法来编译一个正则表达式 created with the RegExp constructor function 。这样

就强制正则表达式只编译一次,而不是每次遇到正则表达式的时候都编译一次。当你确认正则表达式能

保持不变的时候可使用 compile 方法来编译它 ( 在获得它的匹配模式后 ) ,这样就可以在脚本中重复多次使用它。

你亦可以使用 compile 方法来改变在运行期间改变正则表达式。例如,假如正则表达式发生变化,

你可以使用 compile 方法来重新编译该对象来提高使用效率。

使用该方法将改变正则表达式的 source, global ignoreCasesource 属性的值。
constructor 
指出建立对象原型的 function 。注意这个属性的值由函数本身提供,而不是一个字串包含 RegExp name.Property 提供。
 
Javascript 1.1, NES 2.0 以上版本提供 ECMA 版本 ECMA-262 描述:参考
Object.constructor.
exec
方法 在指定的字符串运行匹配搜索。返回一个结果数组。 RegExp 的方法
 
Javascript 1.2, NES 3.0 以上版本提供 语法:
regexp.exec([str])regexp([str])
参数: regexp ,正则表达式的名称,可以是一个变量名或文字定义串。
 
str
,要匹配正则表达式的字符串,如果省略,将使用 RegExp.input 的值。
 
描述:就如在语法描述中的一样,正则表达工的 exec 方法能够被直接调用 ( 使用 regexp.exec(str)) 或者间接调用 ( 使用 regexp(str))

假如你只是运行以找出是否匹配,可以使用 String 搜索方法。

假如匹配成功, exec 方法返回一个数组并且更新正则表达式对象属性的值和预先定义的正则表达式对象、 RegExp 。如果匹配失败, exec 方法返回 null

请看下例: <script LANGUAGE="Javascript1.2"> // 匹配一个 b 接着一个或多个 d ,再接着一个
b
//
忽略大小写
myRe=/d(b+)(d)/ig; myArray = myRe.exec("cdbBdbsbz");
</script>
下面是该脚本的返回值:对象 属性 /Index 描述 例子
 
myArray

myArray 的内容 ["dbBd", "bB", "d"] 
index
基于 0 的匹配
index 1 
input
原始字符串
cdbBdbsbz 
[0]
最后匹配的字符
dbBd 
[1], ...[n]
用圆括号括住的匹配字符串,如果有的话。不限制括号的个数。
[1] = bB
[2] = d 
myRe
lastIndex
开始下次匹配操作的 index

ignoreCase
指出 "i" 是否使用以忽略大小写
true 
global
指出是否使用 "g" 标记来进行匹配所有可能的字串
true 
source
定义模式的文本字符串
d(b+)(d) 
RegExp
lastMatch$&
最后匹配的字符
dbBd 
leftContext$\Q
最新匹配前面的子串

rightContext$'
最新匹配后面的子串
bsbz 
$1, ...$9
圆括号内的匹配子串,如果有的话。圆括号的个数不受限制,但 RegExp 只能保留最后 9
$1 = bB 
$2 = d 
lastParen $+
最后一个加上圆括号的匹配子串,如果有的话

假如你的正则表达式使用了 "g" 标记,你可以多次使用 exec 方法来连续匹配相同的串。当你这样做
的时候,新的匹配将从由正则表达式的 lastIndex 属性值确定的子串中开始。例如,假定你使用下面的脚本:

<script LANGUAGE="Javascript1.2"> myRe=/ab*/g;str = "abbcdefabh"
myArray = myRe.exec(str);
document.writeln("Found "+myArray[0]+". Next match starts at "+myRe.lastIndex)
mySecondArray = myRe.exec(str);
document.writeln("Found "+mySecondArray[0]+". Next match starts at "+myRe.lastIndex)
</script>
这个脚本显示如下结果:
Found abb. Next match starts at 3
Found ab. Next match starts at 9
例子:

在下面的例子中,用户输入一个名字,脚本根据输入执行匹配操作。接着检查数组看是否和其它用户的名字匹配。

本脚本假定已注册的用户的姓已经存进了数组 A 中,或许从一个数据库中取得。
<HTML>
<script LANGUAGE="Javascript1.2"> A = ["zhao","qian","sun","li","liang"]
function lookup() { firstName = /\w+/i(); if (!firstName)
window.alert (RegExp.input + "
非法输入
"); else { count=0;
for (i=0;i
输入你的姓然后按回车键。

<FORM><INPUT TYPE:"TEXT" NAME="FirstName" onChange="lookup(this);"></FORM>
</HTML> global
属性 正则表达式中是否使用了 "g" 标记。 RegExp 属性,只读

Javascript 1.2, NES 3.0 以上版本提供 描述: global 是一个个别正则表达式对象的属性

如果使用了 "g" 标记, global 的值为 true ;否则为 false "g" 标记指定正则表达式测试所有可能的匹配。

你不能直接改变该属性的值,但可以调用 compile 方法来改变它。 ignoreCase 检查正则表达式是否使用了 "i" 标记

RegExp
属性,只读 Javascript 1.2, NES 3.0 以上版本提供 描述:

ignoreCase
是个别正则表达式对象的一个属性。

如果使用了 "i" 标记,则返回 true ,否则返回 false "i" 标记指示在进行匹配的时候忽略大小写。

你不能直接改变该属性的值,但可以通过调用 compile 方法来改变它 input 指出正则表达式要测试那个字串。 $_ 是这个属性的另一个名字。

RegExp
的属性,静态 Javascript 1.2, NES 3.0 以上版本提供
 
描述:因为 input 是静态的,不是某个个别的正则表达式对象的属性。你也可以使用 RegExp.input 来表示。

如果没有给正则表达式的 exec test 方法提供字符串,并且 RegExp.input 中有值,则使用它的值来调用该方法。

脚本或浏览器能够预置 input 属性。如果被预置了值且调用 exec test 方法的时候没有提供字符串

则调用 exec test 的时候使用 input 的值。 input 可以被浏览器以下面的方式设置:

text 表单域处理句柄被调用的时候, input 被设置为该 text 输入的字串。

textarea 表单域处理句柄被调用的时候, input 被设置为 textarea 域内输入的字串。注意
multili
ne
亦被设置成 true 从而能匹配多行文本。 select 表单域处理句柄被调用的时候, input 被设置成 selected text 的值。

当链接对象的处理句柄被调用的时候, input 被设置成 <A HREF=...> </A> 之间的字符串。

事件理现句柄处理完毕后, input 属性的值被清除。 lastIndex 可读 / 可写的一个整数属性,指出下一次匹配从哪里开始。

RegExp
的属性 Javascript 1.2, NES 3.0 以上版本提供
 
描述: lastIndex 是个别的正则表达式对象的属性。 这个属性只有当正则表达式的 "g" 标记被使用以进行全串匹配的时候才被设置。实行以下规则:

如果 lastIndex 大小字符串的长度, regexp.test regexp.exec 失败,且 lastIndex 被设为 0

如果 lastIndex 等于字串的长度且正则表达式匹配空字符串,则正则表达式从 lastIndex 的位置开始匹配。

如果 lastIndex 等于字符串的长度且正则表达式不匹配空字符串,则正则表达式不匹配 input ,且 lastIndex 被置为 0

否则, lastIndex 被设置成最近一次匹配的下一点。 例如,按下面的顺序执行脚本: re = /(hi)?/g 匹配空字符串
 
re("hi")
返回 ["hi", "hi"] lastIndex 置为

re("hi")
返回 [""] ,一个空数组,它的下标为 0 的元素就是匹配字符串。在这种情况下,返回空

串是因为 lastIndex 等于 2( 且仍然是 2) ,并且 "hi" 的长度也是 2 lastMatch 最后一次匹配字符串, $& 是同样的意思。

RegExp
的属性,静态,只读 Javascript 1.2, NES 3.0 以上版本提供
 
描述:因为 lastMatch 是静态的,所以它不是个别指定正则表达式的属性。你也可以使用 RegExp.lastMatch
lastParen
最后一次加上括号的匹配字符串,如果有的话。 $+ 是同样的意思。 RegExp 属性,静态,只读

Javascript 1.2, NES 3.0 以上版本提供
 
描述:因为 lastParen 是静态的,它不是某个个别正则式的属性,你可以使用 RegExp.lastParen 表达同样的意思。

leftContext
最近一次匹配前面的子串, $` 具有相同的意思。 RegExp 的属性,静态,只读

Javascript 1.2, NES 3.0 以上版本提供
 
描述:因为 leftContext 是静态的,不是某一个正则表达式的属性,所以可以使用 RegExp.leftContext 来表达想同的意思。

multiline
反映是否匹配多行文本, $* 是相同的意思。 RegExp 的属性,静态

Javascript 1.2, NES 3.0 以上版本提供
 
描述:因为 multiline 是静态的,而不是某个个别正则表达式的属性,所以能够用 RegExp.multiline 表达相同的意思。

如果允许匹配多行文本,则 multiline true ,如果搜索必须在换行时停止,则为 false

脚本或浏览器能够设置 multiline 属性。当一个 textarea 的事件处理句柄被调用的时候,
multiline
被置为 true 。在事件处理句柄处理完毕后, multiline 属性值被清除。也就是说,如果你设置了
multili
ne
true ,则执行任何的事件处理句柄后, multiline 被置为 false
prototype 
描绘类的原型。你可以根据要求使用 prototype 来增加类的属性或方法。为了获得 prototypes 的资

料,请参阅 RegExp function.prototype.Property 属性。 Javascript 1.1, NES 2.0 版本开始提供

ECMA
版本 ECMA-262 rightContext 最后一次匹配的右边的字符串, $' 是同样的效果。

RegExp
的属性,静态,只读 Javascript 1.2, NES 3.0 以上版本开始提供
 
描述:因为 rightContext 是静态的,不是某个个别正则表达工的属性,可以使用 RegExp.rightContext 来达到相同的效果。

source
一个只读属性,包含正则表达式定义的模式,不包侨 forward slashes "g" "i" 标记。 RegExp 的属性,只读

Javascript 1.2, NES 3.0 以上版本开始提供
 
描述: source 是个别正则表达式对象的属性,你不能直接改变它的值,但可以通过调用 compile 方法来改变它。
test
执行指定字符串的正则表达式匹配搜索,返回 true false RegExp 的方法

Javascript 1.2, NES 3.0 以上版本开始提供 语法:
regexp.test([str])
参数: regexp ,正则表达式的名称,可以是变量名或正则表达式定义文字串

str
,要匹配的字符串,如果省略,将使用 RegExp.input 的值为作参数

描述:当你需要知道一个字符串能否匹配某个正则表达工,可以使用 test 方法 ( String.search

法类似 ) 为了获得更多的信息 ( 但速度将变慢 ) ,可以使用 exec 方法 ( String.match 方法类似 ) 例子:下面的例子显示 test 是否成功的提示:

function testinput(re, str){
if (re.test(str)) midstring = " contains ";
else midstring = " does not contain ";
document.write (str + midstring + re.source); } toSource 
返回一个字符串象征对象的源码 RegExp 的方法 Javascript 1.3 以上版本开始提供 语法:
toSource()
参数:没有 描述: toSource 方法返回下述的值: 对于内置的 RegExp 对象, toSource 返回下面的字符象征源码不可用:

function Boolean(){ [native code] }
RegExp 场合中 , toSource 返回象征源码的字符串,通常这个方法是由 Javascript 内部自动调用而不是不代码中显式调用。

更多请看 Object.toSource toString 返回描绘指定对象的字符串。 RegExp 的方法

Javascript 1.1, NES 2.0 开始提供 ECMA 版本 ECMA-262 语法: toString() 参数:无

描述: RegExp 对象不考虑 Object 对象的 toString 方法;它不继承 Object.toString ,对于 RegExp

象, toString 方法返回一个代表该对象的字符串。 例如:下面的例子显示象征 RegExp 对象的字符串

myExp = new RegExp("a+b+c"); alert(myExp.toString())
displays "/a+b+c/"
更多请看: Object.toString valueOf 返回一个 RegExp 对象的原始值

RegExp
的方法 Javascript 1.1 版本开始提供 ECMA 版本: ECMA-262 语法:
valueOf()
参数:无 描述: RegExp valueOf 方法以字符串形式返回 RegExp 对象的原始值,这个值与 RegExp.toString 相等。

该方法通常由 Javascript 内部自动调用而不是显式调用 例子:
myExp = new RegExp("a+b+c");
alert(myExp.valueOf()) displays "/a+b+c/"