正则表达式中的\2和\1和\3不仅分组还占位

首先你要理解正则中的分组和捕获的概念,

用()括号括起来的匹配会是可获取的,js里总共可以放9个对应用\1....\9来获取重用。

var s = 'abbaabae3ee3abbfd43aaabbby65aabb3a';

var pattern1=/([a-z])/g; 

在这里小写字母就是一个组,正则匹配结果为:s.match(pattern1)

如果pattern1变为/([a-z])\1/g;那么其中的\1代表的就是([a-z])这个结果:

即:如果[a-z]匹配的是a,那么\1也是a,所以最终的正则匹配结果为:s.match(pattern1)

看以下正则:

var s1 = 'abbaa baabb e3ee3abbfd43aaabbby65aabb3a';

var pattern2=/([a-z])([a-z])\2\1{2,}/g; 

s.replace(pattern2,function($4,$0,$1,$2){
console.log('$4:',$4,'$0:',$0,'$1:',$1,'$2:',$2)
});

结果为:

其中的$4代表的是正则匹配的最终结果的其中的一个子项,

粗线和细线部分;

console.log('最终的正则匹配结果为:',s.match(pattern2)):

 重点声明一下:

以下以$4为abbaa为例第一个紫色的匹配为例讲解:

其中的$4,$0,$1,$2并没有什么特定的规矩,只是自己随意命名的,

$0表示\1所匹配的结果,即图片中标红的部分:在该字符串中匹配结果为a,

$1表示\2所匹配的结果,即图片中标蓝的部分:在该字符串中匹配结果为b,

正则中的\1{2,}代表重复次数最少2次,即\1第一个为aa;

以上,结合正则理解如下:

var pattern2=/([a-z])([a-z])\2\1{2,}/g; 

 

其中匹配结果a,

匹配结果b,

匹配结果b,

匹配结果a,

匹配结果aa,综上所述最终结果为

abbaa;

补充一点,对于最后的一个参数$2我不明白是啥意思,不知道有没有大神解答一下,不胜感激。

最后说明一下:

console.log(s.replace(pattern2,function($4,$0,$1,$2){
//console.log('$4:',$4,'$0:',$0,'$1:',$1,'$2:',$2)
$4='test'
return $4;
}));

 自己可以手动修改return返回值,然后修改正则结果。

猜你喜欢

转载自www.cnblogs.com/qiqi105/p/9054861.html