JS正则表达式使用详解(2)
在对如何使用正则表达式有了初步了解之后,我们来看一下其它几个重要的元字符的使用方式。
TEXT 代码:
-
s:用于匹配单个空格符,包括tab键和换行符; -
S:用于匹配除单个空格符之外的所有字符;
-
d:用于匹配从0到9的数字;
-
w:用于匹配字母,数字或下划线字符;
-
W:用于匹配所有与w不匹配的字符;
-
. :用于匹配除换行符之外的所有字符。
(说明:我们可以把\s和\S以及\w和\W看作互为逆运算)
下面,我们就通过实例看一下如何在正则表达式中使用上述元字符。
/\s+/ 上述正则表达式可以用于匹配目标对象中的一个或多个空格字符。
/\d000/ 如果我们手中有一份复杂的财务报表,那么我们可以通过上述正则表达式轻而易举的查找到所有总额达千元的款项。
除了我们以上所介绍的元字符之外,正则表达式中还具有另外一种较为独特的专用字符,即定位符。
定位符用于规定匹配模式在目标对象中的出现位置。
较为常用的定位符包括: “^”, “$”, “\b” 以及 “\B”。
TEXT 代码:
-
“^”定位符规定匹配模式必须出现在目标字符串的开头 -
“$”定位符规定匹配模式必须出现在目标对象的结尾
-
“b”定位符规定匹配模式必须出现在目标字符串的开头或结尾的两个边界之一
-
“B”定位符则规定匹配对象必须位于目标字符串的开头和结尾两个边界之内,
-
即匹配对象既不能作为目标字符串的开头,也不能作为目标字符串的结尾。
同样,我们也可以把“^”和“$”以及“\b”和“\B”看作是互为逆运算的两组定位符。
举例来说:
/^hell/ 因为上述正则表达式中包含“^”定位符,所以可以与目标对象中以 “hell”, “hello”或“hellhound”开头的字符串相匹配。
/ar$/ 因为上述正则表达式中包含“$”定位符,所以可以与目标对象中以 “car”, “bar”或 “ar” 结尾的字符串相匹配。
/\bbom/ 因为上述正则表达式模式以“\b”定位符开头,所以可以与目标对象中以 “bomb”, 或 “bom”开头的字符串相匹配。
/man\b/ 因为上述正则表达式模式以“\b”定位符结尾,所以可以与目标对象中以 “human”, “woman”或 “man”结尾的字符串相匹配。
为了能够方便用户更加灵活的设定匹配模式,正则表达式允许使用者在匹配模式中指定某一个范围而不局限于具体的字符。
例如:
TEXT 代码:
-
/[A-Z]/ 上述正则表达式将会与从A到Z范围内任何一个大写字母相匹配。 -
/[a-z]/ 上述正则表达式将会与从a到z范围内任何一个小写字母相匹配。
-
/[0-9]/ 上述正则表达式将会与从0到9范围内任何一个数字相匹配。
-
/([a-z][A-Z][0-9])+/ 上述正则表达式将会与任何由字母和数字组成的字符串,如 “aB0” 等相匹配。
这里需要提醒用户注意的一点就是可以在正则表达式中使用 “()” 把字符串组合在一起。
“()”符号包含的内容必须同时出现在目标对象中。
因此,上述正则表达式将无法与诸如 “abc”等的字符串匹配,因为“abc”中的最后一个字符为字母而非数字。
如果我们希望在正则表达式中实现类似编程逻辑中的“或”运算,在多个不同的模式中任选一个进行匹配的话,可以使用管道符 “|”。
例如:/to|too|2/ 上述正则表达式将会与目标对象中的 “to”, “too”, 或 “2” 相匹配。
正则表达式中还有一个较为常用的运算符,即否定符 “[^]”。与我们前文所介绍的定位符 “^” 不同,否定符 “[^]”规定目标对象中不能存在模式中所规定的字符串。
例如:/[^A-C]/ 上述字符串将会与目标对象中除A,B,和C之外的任何字符相匹配。
一般来说,当“^”出现在 “[]”内时就被视做否定运算符;
而当“^”位于“[]”之外,或没有“[]”时,则应当被视做定位符。
最后,当用户需要在正则表达式的模式中加入元字符,并查找其匹配对象时,可以使用转义符“\”。
例如:/Th\*/ 上述正则表达式将会与目标对象中的“Th*”而非“The”等相匹配。
在构造正则表达式之后,就可以象数学表达式一样来求值,也就是说,可以从左至右并按照一个优先级顺序来求值。
优先级如下:
TEXT 代码:
-
转义符 -
(), (?:), (?=), [] 圆括号和方括号
-
*, +, ?, {n}, {n,}, {n,m} 限定符
-
^, $, anymetacharacter 位置和顺序
-
|“或”操作
使用实例
在JavaScript 1.2中带有一个功能强大的RegExp()对象,可以用来进行正则表达式的匹配操作。
其中的test()方法可以检验目标对象中是否包含匹配模式,并相应的返回true或false。
我们可以使用JavaScript编写以下脚本,验证用户输入的邮件地址的有效性。
HTML 代码:
-
<script language="Javascript1.2">
-
<!-- start hiding
-
function verifyAddress(obj)
-
{
-
var email = obj.email.value;
-
var pattern =/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/;
-
flag = pattern.test(email);
-
if(flag)
-
{
-
alert(“Your email address is correct!”);
-
return true;
-
}
-
else
-
{
-
alert(“Please try again!”);
-
return false;
-
}
-
}
-
// stop hiding -->
-
</script>
-
</head>
-
<form >
-
<input name="email" type="text">
-
<input type="submit">
-
</form>
-
</body>
-
</html>本对象包含正则表达式模式以及表明如何应用模式的标志。复制内容到剪贴板参数
TEXT 代码:
-
语法 1 re = /pattern/[flags] -
语法 2 re = new RegExp("pattern",["flags"])
re
必选项。将要赋值为正则表达式模式的变量名。
Pattern
必选项。要使用的正则表达式模式。如果使用语法 1,用 "/" 字符分隔模式。如果用语法 2,用引号将模式引起来。
Flags
可选项。如果使用语法 2 要用引号将 flag 引起来。标志可以组合使用,可用的有:复制内容到剪贴板示例TEXT 代码:
-
g (全文查找出现的所有 pattern) -
i (忽略大小写)
-
m (多行查找)
下面的示例创建一个包含正则表达式模式及相关标志的对象(re),向您演示正则表达式对象的用法。在本例中,作为结果的正则表达式对象又用于 match 方法中:复制内容到剪贴板返回值: ain,ain,ain,ain\\JS 代码:
-
function MatchDemo() -
{
-
var r, re; // 声明变量。
-
var s = "The rain in Spain falls mainly in the plain";
-
re = new RegExp("ain","g"); // 创建正则表达式对象。
-
r = s.match(re); // 在字符串 s 中查找匹配。
-
return(r);
-
}
属性 lastIndex 属性 | source 属性\\
方法 compile 方法 | exec 方法 | test 方法\\
要求 版本 3\\
请参阅 RegExp 对象 | 正则表达式语法 | String 对象\\exec 方法
用正则表达式模式在字符串中运行查找,并返回包含该查找结果的一个数组。
rgExp.exec(str)
参数
rgExp
必选项。包含正则表达式模式和可用标志的正则表达式对象。
str
必选项。要在其中执行查找的 String 对象或字符串文字。
说明
如果 exec 方法没有找到匹配,则它返回 null。
如果它找到匹配,则 exec 方法返回一个数组,并且更新全局 RegExp 对象的属性,以反映匹配结果。
数组的0元素包含了完整的匹配,而第1到n元素中包含的是匹配中出现的任意一个子匹配。
这相当于没有设置全局标志 (g) 的 match 方法。
如果为正则表达式设置了全局标志,exec 从以 lastIndex 的值指示的位置开始查找。
如果没有设置全局标志,exec 忽略 lastIndex 的值,从字符串的起始位置开始搜索。
exec 方法返回的数组有三个属性,分别是 input、index 和 lastIndex。
Input 属性包含了整个被查找的字符串。
Index 属性中包含了整个被查找字符串中被匹配的子字符串的位置。
LastIndex 属性中包含了匹配中最后一个字符的下一个位置。
示例
下面的例子举例说明了 exec 方法的用法:复制内容到剪贴板JS 代码:
-
function RegExpTest() -
{
-
var ver = Number(ScriptEngineMajorVersion() + "." + ScriptEngineMinorVersion())
-
if (ver >= 5.5){ // 测试 JScript 的版本。
-
var src = "The rain in Spain falls mainly in the plain.";
-
var re = /w+/g; // 创建正则表达式模式。
-
var arr;
-
while ((arr = re.exec(src)) != null)
-
document.write(arr.index + "-" + arr.lastIndex + arr + "t");
-
}
-
else{
-
alert("请使用 JScript 的更新版本");
-
}
-
}
返回值:0-3The 4-8rain 9-11in 12-17Spain 18-23falls 24-30mainly 31-33in 34-37the 38-43plain
-
浙公网安备 33010602011771号