关于正则的exec方法以及字符串的replace方法

前端之家收集整理的这篇文章主要介绍了关于正则的exec方法以及字符串的replace方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

首先我们书写一个字符串

var str="2015-08-17";
    var reg=/^(\d@H_301_5@{@H_301_5@4}@H_301_5@)(?:-|\\@H_301_5@|\/@H_301_5@)(\d@H_301_5@{@H_301_5@1,2}@H_301_5@)(?:-|\\@H_301_5@|\/@H_301_5@)(\d@H_301_5@{@H_301_5@1,2}@H_301_5@)$/; console.log(reg.exec(str));@H_301_5@

弹出的结果

分析下结果
得到的是一个数组
第一项 是正则匹配到内容
第二项 为第一个分组匹配的内容
第三项 为第二个分组匹配的内容
第四项 为第三个分组匹配的内容
第五项 正则匹配的索引
第六项 为原字符串
值得注意的是正则中加了?:的是不进行捕获的
字符串中的replace方法

var@H_301_5@ str="2015-08-17"@H_301_5@;
    var@H_301_5@ reg=/^(\d{4})(?:-|\\|\/)(\d{1,2})(?:-|\\|\/)(\d{1,2})$/@H_301_5@;
    console.log(Object@H_301_5@.prototype.toString.call(reg.exec(str)));
    str.replace(reg,function@H_301_5@()@H_301_5@{@H_301_5@
       for@H_301_5@(var@H_301_5@ i=0@H_301_5@;i<arguments@H_301_5@.length;i++){
           console.log(arguments@H_301_5@[i]);
       }
    })

结果是 2015-08-17 2015 08 17 0 2015-08-17 可以看到里面其实是有传参数的,传递的参数跟exec捕获到的结果是一样 return xx即将大正则匹配的内容替换掉

猜你在找的正则表达式相关文章