正则表达式是
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
值
5
ignoreCase
指出
"i"
是否使用以忽略大小写
true
global
指出是否使用
"g"
标记来进行匹配所有可能的字串
true
source
定义模式的文本字符串
d(b+)(d)
RegExp
lastMatch$&
最后匹配的字符
dbBd
leftContext$\Q
最新匹配前面的子串
c
rightContext$'
最新匹配后面的子串
bsbz
$1, ...$9
圆括号内的匹配子串,如果有的话。圆括号的个数不受限制,但
RegExp
只能保留最后
9
个
$1 = bB
$2 = d
lastParen $+
最后一个加上圆括号的匹配子串,如果有的话
d
假如你的正则表达式使用了
"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
置为
2
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/"