参考博文
https://www.cnblogs.com/wancheng7/p/8906015.html
var str = 'kid is kid'
var reg = /(\w{3}) is \1/
reg.test(str) == true
这里的正则表达式里的'\1'相当于前面的 (\w{3}) =>即一个分组;这里的\1就
表示匹配的第一个分组;
var str = 'aaaabbbbcccc';
var reg = /(\w{2})/g;
var reg2 = /(\w{2})\1/g;
str.match(reg) =>["aa","aa","bb","bb","cc","cc"]
这里是每两个字母作为一个组匹配出来,得到这样的结果
str.match(reg2) =>["aaaa", "bbbb", "cccc"]
这里是因为'\1'就相当于第一个匹配组,且匹配的内容需要一样,
所以如果str ="aaabbbccc"; 那么str.match(reg2) = null
因为第一个组和\1同时进行匹配的话,无法找到可以匹配的'xxyy'这种字符串
正则捕获到的结果会被储存起来,每一个分组捕获的内容会从1开始被编号储存
var reg = /(\d{4})-(\d{2})-(\d{2})/;
var dateStr = '2018-04-18';
reg.test(dateStr); //true //这一步是需要有的,下面的代码才会有效
RegExp.$1 //2018
RegExp.$2 //04
RegExp.$3 //18
下面的这种处理日期格式的还是比较实用的
var dateStr = '2018/04/18';
var reg = /(\d{4})\/(\d{2})\/(\d{2})/;
dateStr = dateStr.replace(reg, '$1-$2-$3') //"2018-04-18"
虽然dateStr.replace(/\//g,'-')这句代码也可以实现相同的结果,还比较简单,但是
就觉得上面的正则方式的代码很帅;