1.分组
2.贪婪,惰性
3.可重复子项
分组就是使用()与|这俩符号,顾名思义,分个组,一组就当做一个
(ab){3}那就是 ababab过 aaabbb、abbb凉
小竖线是或
3(1|2)3 那么313过 323过
贪婪与惰性,就是是否一直匹配下去
8xxx8 8xxx8 8xxx8
上面这个字符串,
我们用/8.*8/g
来匹配,那么匹配到一处,是整个字符串
我们用/8.*?8/g
来匹配,那么匹配到三处,每处都是8xxx8
贪婪就是多来点,都符合,要多的
惰性就是匹配到就行了,别管下面的了
可重复子项,/1表示,这个正则中,第一处()内的内容
这里我也不清楚()出现嵌套会咋样,实际上,也不会搞成嵌套,可读性太差了
/(\d)\1/g
上面的正则,11过22过 12凉
啥意思呐?就是\1表示第一处()里面的家伙,相当于重新写了一份
下面是个demo:
var str=“hbciyegbiywgbfiwbcuhebduywveuhvdbuwvedugwvdugwveugdvw”
找出来出现次数最多的字母,及出现次数
太乱了,我们搞成数组,排序,搞回字符串
str=str.split(’’").sort().join("");
来正则,这是这类面试题的考察点,你熟悉正则吗?写正则,以及与正则相关的API
const reg=/(\w)\1*/g;
let maxNum=0;
let maxChar=’’;
str.replace(reg,(str,$1)=>{
if(str.length>=maxNum){
maxNum=str.length;
maxChar=$1;
}
})