js正则分组

本文转载于https://www.cnblogs.com/Vibge/p/9831953.html

js 正则表达式分组
正则表达式分组:通俗的就是正则表达式中()包起来的内容表示一个分组

例如:

var reg = /^(\d{2})$/;
var asd = reg.test('12');
console.log(asd); //true

1、利用正则表达式优雅的表达重复的字符串

var reg2 = /^(SD)\d{4}(-\d{4}){3}$/;
console.log(reg2.test('SD0214-0000-0000-0000')); //true

例如:/^(ha){3}$/ 等同于 /^hahaha$/

2 、多个候选表达式

var reg3 = /^I come from (hunan|hubei|zhejiang)$/;
console.log(reg3.test('I come from hunan'));

3、分组的分类:捕获型();非捕获型(?:);正向前瞻性(?=);反向前瞻性(?!)

// 1、获取
var reg4 = /^(\d{4})-(\d{2})-(\d{2})$/
var data = '2018-10-17';
reg4.test(data);
console.log(RegExp.$1); // 输出 2018
console.log(RegExp.$2); // 输出 10
console.log(RegExp.$3); // 输出 17

// 2、结合replace方法做字符串自定义转换
var date2 = '2018/04/18';
var reg5  =/^(\d{4})\/(\d{2})\/(\d{2})$/;
var dateStr = date2.replace(reg5, '$1-$2-$3') //"2018-04-18";
console.log(dateStr); 

// 3、反向引用
var reg6 = /^(\w{3}) is \1$/;
console.log(reg6.test('kid is kid')); // true
console.log(reg6.test('kid is dik')); // false

// 如果越界或者编号不存在,则被解析为普通的表达式
var reg7 = /^(\w{3}) is \6$/;
console.log(reg7.test('kid is \6')); // true
console.log(reg7.test('kid is kid')); // false

// 4、非捕获型分组
var reg8 = /^(?:\d{4})-(\d{2})-(\d{2})$/;
var date3 = '2018-10-18';
reg8.test(date3);  //true
console.log(RegExp.$1); //10
console.log(RegExp.$2); //18
 
// 5、正向与反向前瞻性分组; 正向,站在原地往前看,如果前方是指定的东西就返回true,否则返回false
var reg9 = /^kid is a (?=boy)/;
console.log(reg9.test('kid is a boy')); // true
console.log(reg9.test('kid is a girl'));// false

//6、正向与反向前瞻性分组例子
let reg = /(?=o)/g
let str = 'hello world'
let s = str.replace(reg,'A')
console.log(s)    //输出hellAo wAorld

let reg = /l(?=o)/g
let str = 'hello world'
let s = str.replace(reg,'A')
console.log(s)     //输出helAo world

//反向前瞻型分组:你站在原地往前看,如果前方不是指定的东西则返回true,如果是则返回false
let reg = /(?!l)/g
let str = 'hello'
let s = str.replace(reg,'A')
console.log(s)    //输出AhAellAoA

let reg = /l(?!o)/g
let str = 'hello'
let s = str.replace(reg,'A')
console.log(s)    //输出heAlo
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值