exec:正则捕获
每一次捕获的时候都是先进行默认的匹配,如果没有匹配成功的,捕获的结果是null;只有有匹配的内容才能捕获到
捕获的内容格式:
a、捕获到的内容是一个数组,数组中的第一项是当前大正则捕获的内容
index:(第二项)捕获内容在字符串中开始的索引位置
input:(第三项)捕获的原始字符串
正则捕获的特点:
a、懒惰性:每一次执行exec只捕获第一个匹配的内容,在不进行任何处理的情况下,再执行多次捕获,捕获的还是第一个匹配的内容。
(由lastIndex决定的。lastIndex:是正则每一次捕获在字符串中开始查找的位置,默认的值是0)
解决懒惰性:在正则的末尾加一个修饰符“g”。修饰符:g、i、m
global(g):全局匹配
ignoreCase(i):忽略大小写匹配
multiline(m):多行匹配(不常用)
var reg=/\d+/g;
var str="1111haha2222";
console.log(reg,lastIndex); //---->0
console.log(reg.exec(str)); //----->"1111"
console.log(reg,lastIndex); //---->8
console.log(reg.exec(str)); //-----"2222"
原理:加了全局修饰符g,正则每一次捕获结束后,lastIndex的值都变为了最新的值,下一次捕获从最新的位置开始查找,这样就可以把所有需要捕获的内容都获取到了
获取正则捕获的所有内容(一定不要忘记加g):
var reg=/\d+/g; //出现一到多个0-9之间的数字
var str="haha1234hahah5678hahah4567";
var ary=[];
var res=reg.exec(str);
while(res){
ary.push(res[0]);
res=reg.exec(str);
}
console.log(ary); //--->["1234","5678","4567"]
————————————————————————————————————————
b、正则贪婪性:
正则的每一次捕获都是按照匹配最长的结果捕获的
解决贪婪性:
在量词元字符后面添加一个?即可:
var reg=/\d+?/g;
?在正则中的作用:
(1).放在一个普通的元字符后面代表出现0-1次 /\d?/---->数字可能出现也可能不出现
(2).放在一个量词的元字符后面,取消捕获时的贪婪性 var reg=/\d+?/g; //捕获为1
————————————————————————————————————————
字符串中的match捕获方法:
把所有和正则匹配的字符都获取到
var reg=/\d+?/g;
var str="haha1234hahah5678hahah4567";
var ary=str.match(reg);
console.log(ary); //--->["1","2","3","4","5","6","7","8“,"4”,"5","6","7"]
但match也存在问题:在分组捕获的情况下,match只能捕获到大正则匹配的内容,而对于小正则捕获的内容是无法获取的
字符串的replace捕获方法
replace:将原有的字符替换成我们新的字符
a、在不使用正则的情况下,执行一次replace只能替换字符串中的一个
b、在replace中可以一次批量的把所有正则匹配的内容都替换掉(replace是支持正则的)
原理:先按照正则制定的规则,到字符串中把正则匹配的内容捕获到,然后在每一次捕获到之后,都把捕获的内容替换成新的内容