//一般情況,當(dāng)我們想匹配任意兩個相同的字符(復(fù)雜一點就是兩個相同的分組)時,往往可以借助下面的寫法
//說明:
//(\w)用來匹配任何除了換行和制表符的字符, 而\1是對(\w)的一個引用, 所以你可以理解成: (\w)\1 就是(\w)(\w)
//但是,
//(\w)\1 和 (\w)(\w)的不同之處在于, (\w)(\w)表示任意兩個連續(xù)的字符, 比如Ac, MM, K9, 都可以,
// 但(\w)\1只能是AA, CC, 99 這樣連續(xù)相同的字符
//所以, 你可以這樣理解, \1 是對(\w)的一個實例化引用, 當(dāng)(\w) 匹配到A時, \1 被表達(dá)成A, 當(dāng)(\w)匹配9時, \1 被表示成9
//說了這么多, 可能有些廢話, 下面這個例子就很好理解了
var str = "AA Am 99";
var reg = /(\w)\1/g;
str.match(reg);//輸出: ["AA", "99"]
例子
function containsRepeatingLetter(str) {
return /([a-zA-Z])\1/.test(str);
}
給定字符串 str,檢查其是否包含連續(xù)重復(fù)的字母(a-zA-Z),包含返回 true,否則返回 false