正则(?:pattern)与(?=pattern)的区别

·  阅读 1710

之前在 edabit 做练习时遇到题目,遇到这个问题发现不懂!

搜了文章

(pattern) : 匹配 pattern 并获取这一匹配,所获取的匹配可以从产生的 Matches 集合得到。

(?:pattern) :匹配 pattern 但不获取匹配结果,也就是说这是一个非获取匹配,不进行存储供以后使用。

(?=pattern) :正向预查,在任何匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始。

共同点

(?:pattern)(?=pattern)都匹配pattern,但不会把pattern结果放到Matches的集合中,即Matcher.group()不会匹配到(?;pattern)与(?=pattern)

区别

  • (?:pattern) 匹配得到的结果包含pattern,(?=pattern) 则不包含。如:

    对字符串:"industry abc"的匹配结果:
    复制代码

    var reg =/industr(?:y)/ var str="industry abc" str.match(reg); 输出:["industry", index: 0, input: "industry abc", groups: undefined]

    var reg =/industr(?=y)/ var str="industry abc" str.match(reg); ["industr", index: 0, input: "industry abc", groups: undefined]

是否消耗字符
(?:pattern) 消耗字符,下一字符匹配会从已匹配后的位置开始。
(?=pattern) 不消耗字符,下一字符匹配会从预查之前的位置开始。
即后者只预查,不移动匹配指针。如:

下面在来个题目巩固一下:

题目:

创建一个特殊的正则表达式,以检测GET请求是否有效。

字符串的格式如下:

name1=val1&name2=val2&name3=val3&name4=val4
复制代码

您需要使用四个名称检测请求:“ val”,“ id”,“ desc”,“ time”(每个值可以具有不同的顺序)。

例如:

"val=val1&id=val2&desc=val3&time=val4"

"id=val2&val=val1&time=val4&desc=val3"
复制代码

每个名称都有一个特定的值:

  1. **

    val 可以包含字符串a到z和数字0到9(任何情况下都可以接受)。

    **

  2. **

    id 是从0到10的数字。

    **

  3. **

    desc 可以包含字符串a到z。

    **

  4. **

    时间 是格式化值(00:00到99:99)。

    **

例如:

"val=test1151&id=5&desc=helloWorld&time=54:33"

"id=10&val=123test&time=99:00&desc=itsok"

答案:
const regExp = /(?=.*&?desc=([a-zA-Z]+)(?:&\w|$))(?=.*&?val=([a-zA-Z0-9]+)(?:&\w|$))(?=.*&?time=(\d{2}:\d{2})(?:&\w|$))(?=.*&?id=(10|[0-9])(?:&\w|$))^[^&][^-]*[^&]$/;
function dataRegexLovely(str) {
	var m = str.match(regExp);
  return {
    desc: m[1],
    val: m[2],
    time: m[3],
    id: +m[4]
  };
}
复制代码

文章来源:www.cnblogs.com/silver-airc…

匹配html 标签 var reg=/(?:<)([a-z1-9]+)[^<>/]*(?:>)/g;

分类:
前端
标签:
分类:
前端
标签:
收藏成功!
已添加到「」, 点击更改