(1)((2))(3)
$1 是第一个括号
$2 是第二个括号
$3 是第二个括号中的括号
$4 是第三个括号
http://www.jb51.net/article/28007.htm
http://www.jb51.net/article/46378.htm
正则表达式具有如下属性
正则表达式会记录下一次开始执行时索引位置
【1】str.match(reg) 返回所有匹配的结果数组(g情况也包括)
使用正则表达式模式对字符串执行查找,并将包含查找的结果作为数组返回。
如果match的表达式匹配了全局标记g将出现所有匹配项,而不用循环,但所有匹配中不会包含子匹配项。
var s = "The rain in Spain falls mainly in the plain"; re = /(a)in/ig; // 创建正则表达式模式。 r = s.match(re); // 尝试去匹配搜索字符串。 document.write(r); // 返回的数组包含了所有 "ain" 出现的四个匹配,r[0]、r[1]、r[2]、r[3]。 // 但没有子匹配项a。}输出结果:ain,ain,ain,ain
【2】exec 方法
用正则表达式模式在字符串中查找,并返回该查找结果的第一个值(数组),如果匹配失败,返回null。
rgExp.exec(str)
用正则表达式模式在字符串中查找,并返回该查找结果的第一个值(数组),如果匹配失败,返回null。
rgExp.exec(str)
返回数组包含:
数组也是一个对象,exec返回的数组定义了input、index属性
input:整个被查找的字符串的值;
index:匹配结果所在的位置(位);
arr:结果值,arr[0]全匹配结果,arr[1,2...]为表达式内()的子匹配,由左至右为1,2...。
input:整个被查找的字符串的值;
index:匹配结果所在的位置(位);
arr:结果值,arr[0]全匹配结果,arr[1,2...]为表达式内()的子匹配,由左至右为1,2...。
如果为正则表达式设置了全局标记g,exec 从以 lastIndex 的值指示的位置开始查找。如果没有设置全局标志,exec 忽略 lastIndex 的值,从字符串的起始位置开始搜索。利用这个特点可以反复调用exec遍历所有匹配,等价于match具有g标志。
当然,如果正则表达式忘记用g,而又用循环(比如:while、for等),exec将每次都循环第一个,造成死循环。
exec的输出将包含子匹配项。
【3】简单实例对比,比较这俩不同看下面两个的输出结果就可以
function execDemo(){
var r, re; // 声明变量。
var s = "The rain in Spain falls mainly in the plain";
re = /[\w]*(ai)n/i
g;
r = re.exec(s);
res = s.match(re);
}
window.onload = execDemo();
不设置全局标志g,match和exec返回相同的结果
设置全局标志
exec一次返回一个匹配的结果,包含子结果。下一次开始位置是上一次结束之后的位置
match一次返回所有匹配的结果,但不包含子数组
【4】rgexp.test(str)
test()继承正则表达式的lastIndex属性,表达式在匹配全局标志g的时候须注意。
例子5:
function testDemo(){
var r, re; // 声明变量。
var s = "I";
re = /I/ig; // 创建正则表达式模式。
document.write(re.test(s) + "
"); // 返回 Boolean 结果。
document.write(re.test(s) + "
");
document.write(re.test(s));
}
testDemo();
输出结果:
true
false
true
当第二次调用test()的时候,lastIndex指向下一次匹配所在位置1,所以第二次匹配不成功,lastIndex重新指向0,等于第三次又重新匹配。
例子5:
复制代码代码如下:
function testDemo(){
var r, re; // 声明变量。
var s = "I";
re = /I/ig; // 创建正则表达式模式。
document.write(re.test(s) + "
"); // 返回 Boolean 结果。
document.write(re.test(s) + "
");
document.write(re.test(s));
}
testDemo();
输出结果:
true
false
true
当第二次调用test()的时候,lastIndex指向下一次匹配所在位置1,所以第二次匹配不成功,lastIndex重新指向0,等于第三次又重新匹配。
【5】search 方法
返回与正则表达式查找内容匹配的第一个子字符串的位置(偏移位)
function SearchDemo(){
var r, re; // 声明变量。
var s = "The rain in Spain falls mainly in the plain.";
re = /falls/i; // 创建正则表达式模式。
re2 = /tom/i;
r = s.search(re); // 查找字符串。
r2 = s.search(re2);
return("r:" + r + ";r2:" + r2); // 返回 Boolean 结果。
}
document.write(SearchDemo());
var r, re; // 声明变量。
var s = "The rain in Spain falls mainly in the plain.";
re = /falls/i; // 创建正则表达式模式。
re2 = /tom/i;
r = s.search(re); // 查找字符串。
r2 = s.search(re2);
return("r:" + r + ";r2:" + r2); // 返回 Boolean 结果。
}
document.write(SearchDemo());
输出:r:18;r2:-1
search只查找一次,即使设置了g。重复调用也是从起始位置开始
【6】stringObj.split([separator[, limit]])
split 方法的结果是一个字符串数组,在 stingObj 中每个出现 separator 的位置都要进行分解。separator 不作为任何数组元素的部分返回。
【7】stringObj.replace(rgExp, replaceText)
rgExp:正则表达式、字符串、文字
【8】构造函数属性
RegExp.$1