正則表達式分組:通俗的就是正則表達式中()包起來的內容表示一個分組
例如:
1 var reg = /^(\d{2})$/; 2 var asd = reg.test('12'); 3 console.log(asd);
結果是 true;
1、利用正則表達式優雅的表達重復的字符串
1 var reg2 = /^(SD)\d{4}(-\d{4}){3}$/; 2 console.log(reg2.test('SD0214-0000-0000-0000'))
結果 true;
例如:/^(ha){3}$/ 等同於 /^hahaha$/
2 、多個候選表達式
1 var reg3 = /^I come from (hunan|hubei|zhejiang)$/; 2 console.log(reg3.test('I come from hunan'));
3、分組的分類:捕獲型();非捕獲型(?:);正向前瞻性(?=);反向前瞻性(?!)
1 // 1、獲取 2 var reg4 = /^(\d{4})-(\d{2})-(\d{2})$/ 3 var data = '2018-10-17'; 4 reg4.test(data); 5 console.log(RegExp.$1); // 輸出 2018 6 console.log(RegExp.$2); // 輸出 10 7 console.log(RegExp.$3); // 輸出 17 8 9 // 2、結合replace方法做字符串自定義轉換 10 var date2 = '2018/04/18'; 11 var reg5 =/^(\d{4})\/(\d{2})\/(\d{2})$/; 12 var dateStr = date2.replace(reg5, '$1-$2-$3') //"2018-04-18"; 13 console.log(dateStr); 14 15 // 3、反向引用 16 var reg6 = /^(\w{3}) is \1$/; 17 console.log(reg6.test('kid is kid')); // true 18 console.log(reg6.test('kid is dik')); // false
19 // 如果越界或者編號不存在,則被解析為普通的表達式 20 var reg7 = /^(\w{3}) is \6$/; 21 console.log(reg7.test('kid is \6')); // true 22 console.log(reg7.test('kid is kid')); // false 23 24 // 4、非捕獲型分組 25 var reg8 = /^(?:\d{4})-(\d{2})-(\d{2})$/; 26 var date3 = '2018-10-18'; 27 reg8.test(date3); 28 console.log(RegExp.$1); 29 console.log(RegExp.$2); 30 31 // 5、正向與反向前瞻性分組; 正向,站在原地往前看,如果前方是指定的東西就返回true,否則返回false 32 33 var reg9 = /^kid is a (?=doubi)$/; 34 console.log(reg9.test('kid is a doubi')); // true 35 console.log(reg9.test('kid is a shabi'));// false
