加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

正则表达式 分组捕获(反向引用)

发布时间:2020-12-14 01:14:15 所属栏目:百科 来源:网络整理
导读:http://www.cnblogs.com/hejia/archive/2013/03/04/2942301.html 非捕获性分组: 创建反向引用的分组,这种分组一般称为捕获性分组。同时也存在一种非捕获性分组。它不会创建反向引用,因为在比较长的正则表达式中,分组多了会很影响效率。所以使用非捕获性


http://www.cnblogs.com/hejia/archive/2013/03/04/2942301.html


非捕获性分组:

创建反向引用的分组,这种分组一般称为捕获性分组。同时也存在一种非捕获性分组。它不会创建反向引用,因为在比较长的正则表达式中,分组多了会很影响效率。所以使用非捕获性分组。

创建非捕获性分组是这样的(?:开始然后写表达式。例如:

var str='#123456';

//var oReg=/#(w+)/g;  //()的作用有多种,其中一咱就是捕获性分组,有些书上也称做“反向引用”,


var oReg=/#(?:w+)/;  //非捕获性分组 ,在()左边添加 ?:

alert(oReg.test(str));   //true

alert(RegExp.$1);  //  '' 返回空值,由此可以它虽然满足了我们的要求但却并没有创建引用,而如果使用捕获性分组,这里就会返回一个 123456 ,因为RegExp.$1 “记忆”下了匹配的字符。

注意:在JavaScript中,分组匹配的结果是存储在RegExp中的,如果我们使用的是捕获性分组,那么就都可以通过RegExp.$1,RegExp.$2...来取得相应的分组匹配结果,第一个()表示RegExp.$1,第二个()表示RegExp.$2,依此类推。。。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读