欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

javascript - 一个非捕获分组的简单问题

程序员文章站 2022-05-25 15:06:55
...
我在读jQuery代码的时候, 看到一个正则表达式定义
rsingleTag = /^(?:)?$/
rsingleTag用来匹配简单的html标签,
其中有一段非捕获分组:(?:), 问题来了:
为什么要用非捕获分组, 不用的话又怎么样?

例如这个正则表达式中也用到你非捕获分组:
rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/

为什么要用非捕获分组?
在正则表达式的哪个位置用?

回复内容:

我在读jQuery代码的时候, 看到一个正则表达式定义
rsingleTag = /^(?:)?$/
rsingleTag用来匹配简单的html标签,
其中有一段非捕获分组:(?:), 问题来了:
为什么要用非捕获分组, 不用的话又怎么样?

例如这个正则表达式中也用到你非捕获分组:
rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/

为什么要用非捕获分组?
在正则表达式的哪个位置用?

那就反问下自己非捕获分组是什么,从哪里知道的这个「名词」?
那么问题来了,非捕获性分组是干嘛的?

是你不想被捕获到的分组,在js中,一个小括号包起来的字符就是一个分组。在写正则的时候有时候必须用小括号来对一组同类型的字符进行分组,例如 /(abc){3}/,abc三个字母匹配三次,abc就是同类型的字符。但是在match或者exec或者replace等等方法中并不需要这一组字符,于是就不捕获咯。想一想下面这个需求
有一段字符串,使用 n 个 abcd 加一段其他字符组成的,现在我想要n个abcd后面的字符串怎么写

例如 abcdabcdabcdefg,想要的是 efg

'abcdabcdabcdefg'.match(/(abcd)+(.+)/) => ["abcdabcdabcdefg", "abcd", "efg"]
'abcdabcdabcdefg'.match(/(?:abcd)+(.+)/) => ["abcdabcdabcdefg", "efg"]

不写好像也能获得,但是当你正则写的特别长的时候,会出现一堆没用的结果,看着都头疼吧。

=============
再补句话,你问这些问题的时候,自己把控制台调出来,把加了?:和没加的结果输出一遍不就知道了。