在js的正则表达式是一个是一个字述字符模式的对象.它的格式是:
var pattern = /hello/img;
其中 img 代表搜索的模式:
i ignore case 不区分大小写
g global 全局
m multiline 多行
hello 则是需要搜索的字符串,而搜索字符串的书写方法有着很多的形式,其中一种就是:
var pattern = /([a-z]){2}\1/ig;
其意义是:搜索两个 a到z之间的字符在加上一个第一个括号中的字符。但是在使用是并不是这样,在下面的代码中就出现了问题:
var str = 'aabbcc';
var patter = /([a-z]){2}\1/ig;
onsole.log(str.match(patter));
这段代码返回的是abb
本来预想的是返回aab,但是结果并不是。这是因为在()与 \n 出现时 \n 是搜索一个与第n个()搜索到的内容一样的内容,如下:
var str = 'ababcc';
var patter = /([a-z])([a-z])\1/ig;
console.log(str.match(patter)); //aba
var patter = /([a-z])([a-z])\2/ig;
console.log(str.match(patter)); //bcc
第一个返回 aba 因为 \1 要返回和第一个 ([a-z])返回结果一样的字符,第二个返回 bcc 则是 \2 要返回和第二个([a-z])返回一样的字符。
而在第一段代码中:
var str = 'aabbcc';
var patter = /([a-z]){2}\1/ig;
onsole.log(str.match(patter));
因为用([a-z]){2} 代替了([a-z])([a-z])的写法 \1 去搜索与第一个([a-z])搜索到的值,但是有着{2}的存在 \1 是去搜索([a-z])第二个搜索到的值,因此结果为abb
当我们使用这段代码时:
var str = 'aabbcc';
var patter = /([a-z]){2}\1/i;
console.log(str.match(patter));
返回['abb','b'] ,因为match在搜索模式中没有g时:当正则表 达式中没有g修饰符的时候,就不是全局匹配。这时,数组的第一个元素就为匹配的字符串,剩 余的元素则是由正则表达式中用圆括号括起来的子表达式。
因此可以知道 \1 使用的括号中的值是 b ,所以才会搜索出 abb 来。
由此可知在有{n}作用时\1去搜索的是{n}中最后一个括号中的值。