资讯专栏INFORMATION COLUMN

[ JS 进阶 ] test, exec, match, replace

why_rookie / 747人阅读

摘要:用法介绍注为的实例为的实例用法说明返回值判断是否包含匹配结果包含返回,不包含返回。当为全局的对象的时候,替换每一项匹配项。如下表所示,它说明从模式匹配得到的字符串将用于替换。字符替换文本与中的第到第个子表达式相匹配的文本。

上面这四个方法在js中用的很多,但有时对它们又不清晰,所以有必要来总结一下。

对了,这篇文章可能会涉及到正则表达式相关知识,所以推荐没有正则基础的去看看这篇入门文章:正则表达式30分钟入门教程,很经典的文章,反正我的正则就是从这里学的,^▽^ 。

用法介绍

注:patternRegExp的实例, strString的实例

用法 说明 返回值
pattern.test(str) 判断str是否包含匹配结果 包含返回true,不包含返回false
pattern.exec(str) 根据patternstr进行正则匹配 返回匹配结果数组,如匹配不到返回null
str.match(pattern) 根据pattern对str进行正则匹配 返回匹配结果数组,如匹配不到返回null
str.replace(pattern, replacement) 根据pattern进行正则匹配,把匹配结果替换为replacement 一个新的字符串
RegExp对象方法 test()

字符串的test方法,比较常用在判断语句中,最简单的RegExp方法了,用于检测一个字符串是否匹配某个模式:

RegExpObject.test(string)

如果字符串 string 中含有与 RegExpObject 匹配的文本,则返回 true,否则返回 false:

/d/.test("asdf2") // --true   检测字符串`"asdf2"`中是否函数数字
exec()

exec()方法功能非常强大,它是一个通用的方法方法,用于比较复杂的模式匹配或者是说你为你提供更多的信息:

RegExpObject.exec(string)

如果在string中找到了匹配的文本,则返回一个包含这些文本的数组,否侧返回null。这里有几个注意的地方:

返回的数组的第一个元素是与整个正则匹配的文本
然后数组的第二个元素是与整个正则的第一个子表达式(分组)相匹配的文本
数组的第三个元素整个正则的第二个子表达式(分组)相匹配的文本,以此类推。

```
var result = /(d+)-(w+)/.exec("12-ab");
console.log(result) // --> ["12-ab", "12", "ab", index: 0, input: "12-ab"] 
//为什么上面返回的“数组”是那么奇怪,按照[w3school][2]的说法就是:exec() 都会把完整的细节添加到它返回的数组中,这里的细节指的就是index和input
```

整个正则表达式匹配的文本:`"12-ab"`
第一个子表达式匹配的文本:`"12"`
第二个子表达式匹配的文本:`"ab"`

从上面返回的数组结果可知,数组添加了两个额外的属性,分别是:index, input
index: 匹配文本的第一个字符的位置.
input: 顾名思义,就是指输入的整体的文本了.

```
console.log(result.index) // --> 0
console.log(result.input) // --> "12-ab"
```

执行exec函数时,尽管是全局匹配的正则表达式,但是exec方法只对指定的字符串进行一次匹配,
获取字符串中第一个与正则表达式想匹配的内容,并且将匹配内容和子匹配的结果存储到返回的数组中,
例如:/d/g.exec("a22") ,返回的结果和上面的结果一样: ["2"]

    /d/g.exec("a22") // -->["2"]

深入了解 exec()

深入前看看RegExp的实例有哪些属性:

global: 布尔值,表示是否设置了 g 标志

ignoreCase: 布尔值,表示是否设置了 i 标志

lastIndex: 搜索下一个匹配项时开始的位置,从0开始

multiline: 布尔值,表示是否设置了 m 标志

source: 正则表达式的字符串表示

这里稍微陌生一点的就是lastIndex属性了,因为我们不会显示的需要用到它。但它还是挺重要的:

例1:非全局匹配

var reg = /d/;
//第一次匹配
console.log(reg.exec("a123"));
console.log(reg.lastIndex);
//输出
["1"]
  0
  
第二次匹配
console.log(reg.exec("a123"));
console.log(reg.lastIndex);
//输出
["1"]
  0 

结论:

同一正则表达式,在非全局匹配模式下,每次实例的lastIndex属性的值总是不变的(为第一次找到匹配文本所在的位置,上面为0 );

每次的匹配查找都是将lastIndex作为起始位置的

例2:全局匹配

var reg = /d/g;
//第一次匹配
console.log(reg.exec("a123"));
console.log(reg.lastIndex);
//输出
["1"]
  2
  
第二次匹配
console.log(reg.exec("a123"));
console.log(reg.lastIndex);
//输出
["2"]
  3 

第三次匹配
console.log(reg.exec("a123"));
console.log(reg.lastIndex);
//输出
["3"]
  4 

第四匹配
console.log(reg.exec("a123"));
console.log(reg.lastIndex);
//输出
null
  0

结论:

同一正则表达式,在全局匹配模式下,每次实例的lastIndex属性的值为匹配文本最后一个字符的下一个位置,上面例子中第一次匹配的时候最后一个字符位置为1,则下一个位置为:2

当 exec() 再也找不到匹配的文本时,它将返回 null,并把 lastIndex 属性重置为 0。

那当要获取全局匹配的全部匹配项时,可以通过循环来获取:

var reg = /d/g,
    result = [],
    crt;
while((crt = reg.exec("a123")) !== null){
    result = result.concat(crt)
};
result; //["1", "2", "3"]
String对象方法 1. match()

match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。在一定程度上它与上面的exec()有些相似,看一下吧:

例1:非全局匹配

var a = "aaaa".match(/w/);
console.log(a); // ["a", index: 0, input: "aaaa"]

可以看到,和exec()一样,在数组中返回了index 和 input属性。

例2:全局匹配

var a = "aaaa".match(/w/g);
console.log(a); // ["a", "a", "a", "a"]

全局匹配就和exec方法有很大的不同了,他直接返回了所有符合匹配的子字符串的数组,另外,index和input属性也不在其中了,所以这个方法效率可能会高一些,但是如果你需要更多的信息,则用exec()

2. replace()

这也是一个比较灵活常用的方法,它用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。

这个方法接收两个必须的参数:

pattern: 这个参数可以是字符串或是RegExp对象

replacement: 替换匹配项的字符串或处理函数的返回值

返回结果

当未找到匹配项的时候,返回原始字符串。

    "aaaa".replace("bbb", "b")     //"aaaa"
   

当pattern为字符串或者为非全局的RegExp对象的时候,只替换找到的第一项匹配项。

    "aaaa".replace("a", "b")     //"baaa"
    "aaaa".replace(/w/, "b")    //"baaa"

当pattern为全局的RegExp对象的时候,替换每一项匹配项。

    "aaaa".replace(/w/g, "b")    //"bbbb"

replacement:为函数时

"aaaa".replace(/w/g, function() {
    return "b";
}); // "bbbb"

"aaaa".replace(/w/g, function(value) {
    return value.toUpperCase();
}); // "AAAA"

结论:

函数的返回值将作为替换字符串

函数的第一个参数的值是每一个匹配项,当然还有第二个参数,它的值是每个匹配项在原始字符串的中位置,从0开始

特殊的 $:

replacement 中的 $ 字符具有特定的含义。如下表所示,它说明从模式匹配得到的字符串将用于替换。

字符 替换文本
$1、$2、...、$99 regexp 中的第 1 到第 99 个子表达式相匹配的文本。
$& regexp 相匹配的子串
$` 位于匹配子串左侧的文本
$" 位于匹配子串右侧的文本
$$ 直接量符号

来一发:

//第一种情况:
"aa11AA".replace(/([a-z]+)(d+)([A-Z]+)/g, "$1"); // "aa"
"aa11AA".replace(/([a-z]+)(d+)([A-Z]+)/g, "$2"); // "11"
"aa11AA".replace(/([a-z]+)(d+)([A-Z]+)/g, "$3"); // "AA"
    //猜想 如果是 $4 回事什么呢? undefined ? 
    "aa11AA".replace(/([a-z]+)(d+)([A-Z]+)/g, "$4"); // "$4"
    //所以,要是没有该子项,则当成普通字符串处理了
    
//第二种情况:
"aa11AA".replace(/([a-z]+)(d+)([A-Z]+)/g, "$&"); //"aa11AA"

//第三种情况:
"aa11AA".replace(/(d+)/g, "$`"); //"aaaaAA"

//第四种情况:
"aa11AA".replace(/(d+)/g, "$""); //"aaAAAA"

//第五种情况:
"aa11AA".replace(/(d+)/g, "$$"); //"aa$AA"

先这样吧,有问题再补充了,( ╯□╰ )

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/85916.html

相关文章

  • 29.22分钟学会书写正则(2)

    摘要:写在前面的一些废话没有看过上一篇文章的盆友有福了今天没错就是现在我将免费免费将上篇文章的链接发出来这里是上篇上回说了怎么写出正则,这次展示下在中使用正则的场景正则对象属性的正则对象有以下几个属性,其中前面三个也叫修饰符也就是表达式两条杠后面 写在前面的一些废话 没有看过上一篇文章的盆友有福了! 今天!没错!就是现在!我将免费!all f*cking FREE! 免费将上篇文章的链接发出...

    Blackjun 评论0 收藏0
  • JavaScript进阶学习(一)—— 基于正则表达式的简单js模板引擎实现

    摘要:基本语法构造函数可创建一个正则表达式对象,用特定的模式匹配文本。要表示字符串,字面量形式不使用引号,而传递给构造函数的参数使用引号。当使用构造函数创造正则对象时,需要常规的字符转义规则在前面加反斜杠。结果替换与正则表达式匹配的子串。 文章来源:小青年原创发布时间:2016-06-26关键词:JavaScript,正则表达式,js模板引擎转载需标注本文原始地址: http://zhaom...

    Magicer 评论0 收藏0
  • JavaScript正则进阶之路——活学妙用奇淫正则表达式

    摘要:正则大法好,正则大法好,正则大法好,重要的事情说三遍。第二部分,这个部分是整个表达式的关键部分。学习正则如果还没有系统学习正则表达式,这里提供一些网上经典的教程供大家学习。正则表达式使用单个字符串来描述匹配一系列匹配某个句法规则的字符串。 原文收录在我的 GitHub博客 (https://github.com/jawil/blog) ,喜欢的可以关注最新动态,大家一起多交流学习,共同...

    BearyChat 评论0 收藏0
  • JavaScript正则进阶之路——活学妙用奇淫正则表达式

    摘要:正则大法好,正则大法好,正则大法好,重要的事情说三遍。第二部分,这个部分是整个表达式的关键部分。学习正则如果还没有系统学习正则表达式,这里提供一些网上经典的教程供大家学习。正则表达式使用单个字符串来描述匹配一系列匹配某个句法规则的字符串。 原文收录在我的 GitHub博客 (https://github.com/jawil/blog) ,喜欢的可以关注最新动态,大家一起多交流学习,共同...

    APICloud 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<