RegExp对象的exec方法和String对象的match方法用法十分相似,分两篇博客讲讲其各自的用法和它们之间的异同。上一篇将exec方法的用法,这篇讲解match方法,并比较其异同。

定义与语法

【定义】

match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。

【语法】

stringObject.match(searchvalue)
stringObject.match(regexp)

【返回值】存放匹配结果的数组。

以下分3种情况讲解:

1)输入参数为普通字符串;

2)输入参数为非全局正则表达式;

3)输入参数为全部正则表达式。

输入为普通字符串

var str="web2.0 .net2.0";
var searchValue="e";
console.log(str.match(searchValue));

结果如下:

第一项:匹配到的字符串;

属性index:匹配字符串所在的位置;

属性input:输入的字符串

其实,在输入参数为普通字符串时,match方法与indexOf方法的作用类似,只是indexOf返回的是匹配字符串所在的位置,match返回的是匹配的字符串(可以通过index属性获得位置)。但如果只是要获得匹配的字符串就没有意义了,因为结果就是输入参数,所以一般match更多地用于在字符串中匹配模式。

输入为非全局RegExp对象

var str="web2.0 .net2.0";
var pattern=/(\w+)(\d)\.(\d)/;//没有全局标志g
console.log(str.match(pattern));

结果如下:

如果看过上一篇文章exec方法的用法,会发现结果与exec方法的结果完全相同。即:

第一项:web2.0,与整个模式匹配的结果,也就是与/(\w+)(\d)\.(\d)/匹配的结果;

第二项:web,与第一个匹配组匹配的结果,也就是与(\w+)匹配的结果;

第三项:2,与第二个匹配组匹配的结果,也就是与(\d)匹配的结果;

第四项:0,与第三个匹配组匹配的结果,也就是与(\d)(第二个(\d))匹配的结果;

属性一:index:0,匹配项在字符串中的位置,也就是数组第一项的匹配字符串的位置。

属性二:input:"web2.0 .net2.0",也就是输入参数str。

所以,当输入参数为非全局正则表达式时,match方法与exec方法结果一样,均为第一个匹配项的信息(包括捕获组匹配到的子字符串)。

输入为全局RegExp对象

var str="web2.0 .net2.0";
var pattern=/(\w+)(\d)\.(\d)/g;//有全局标志g
console.log(str.match(pattern));

结果如下:

可以发现,结果包含两项,分别为第一个匹配项和第二个匹配项,不包括捕获组的匹配结果,也没有index和input属性。

总结

1)match方法为String对象的方法,输入参数可以为普通字符串或RegExp对象;

2)输入为普通字符串时,结果为一个数组,包含第一个匹配到的字符串;数组有两个属性,分别为匹配字符串的位置index和输入参数input;

3)输入为非全局RegExp对象时,结果为一个数组,包含第一个匹配项的信息,格式为[与整个模式匹配的字符串,与第一个捕获组匹配的字符串,与第二个捕获组匹配的字符串,……],数组有两个属性,分别为匹配得到的字符串的位置index和输入参数字符串input;

4)输入为全局RegExp对象时,结果为一个数组,包含所有匹配的结果,但不包含捕获组匹配的子字符串、index属性和input属性。

exec()和match()异同

1)exec()为RegExp对象的方法,输入参数为字符串;match()为String对象的方法,输入参数为字符串或者RegExp对象;

2)当RegExp对象没有全局标志g时,exec()和match()方法返回结果相同,为一个包含第一个匹配项的信息的数组,格式为[与整个模式匹配的字符串,与第一个捕获组匹配的字符串,与第二个捕获组匹配的字符串,……],数组有两个属性,分别为匹配得到的字符串的位置index和输入参数字符串input;

3)当RegExp对象有全局标志g时,exec()方法每次执行时是从上次检索的终点开始检索,返回当前检索到的一个匹配项信息;match()方法执行的结果为一个包含所有匹配项的数组,不包括捕获组匹配的子字符串、index属性和input属性。

String对象的match方法的更多相关文章

  1. JavaScript中String对象的match()、replace() 配合正则表达式使用

    正则表达式由来已久,查找替换功能非常强大,但模板难记复杂. JavaScript中String对象的match().replace()这2个方法都要使用正则表达式的模板.当模板内容与字符串不相匹配时, ...

  2. String对象的常见方法

    String 对象方法 方法 描述 anchor() 创建 HTML 锚. big() 用大号字体显示字符串. blink() 显示闪动字符串. bold() 使用粗体显示字符串. charAt() ...

  3. JS中string对象的一些方法

    原文地址(包含所有的string对象的方法):  http://www.dreamdu.com/javascript/object_string/ string.slice(startPos,endP ...

  4. JS基础语法---String对象下的方法(字符串的方法)

    实例方法---->必须要通过new的方式创建的对象(实例对象)来调用的方法 静态方法---->直接通过大写的构造函数的名字调用的方法(直接通过大写的对象名字调用的) 字符串的常用属性: . ...

  5. java中String对象的split方法

    在java.lang包中有String.split()方法,返回是一个String[]数组,今天碰到一个自己没注意的问题: 1.特殊分隔符 String str1 = "123|456|78 ...

  6. String对象的简单方法(特别讲解length()方法的实现。

    length() 返回字符串中的字符数 charAt(index) 返回字符串中指定位置的字符 concat(s1)    将本字符串和字符串s1连接,返回一个新字符串 toUpperCase() 返 ...

  7. JS中String对象常用的方法

    1.  stringObject.charAt(index) 参数:index 必需,即字符在字符串中的下标.  返回值:   返回在指定位置的字符.返回的字符是长度为 1的字符串.(length属性 ...

  8. JavaScript RegExp对象的exec()方法

    JavaScript RegExp对象的exec()方法用来匹配字符串,它的行为与match()有些不同. 对于RegExpObject.exec(),w3school上面是这样介绍的: exec() ...

  9. RegExp对象的exec方法

    RegExp对象的exec方法和String对象的match方法用法十分相似,分两篇博客讲讲其各自的用法和它们之间的异同. 下一篇讨论match方法的用法和两者的异同. 定义及语法 [定义] exec ...

随机推荐

  1. ASP.NET:Application,Session,Cookie,ViewState和Cache之间的区别(转)

    在ASP.NET中,有很多种保存信息的对象.例如:Application,Session,Cookie,ViewState和Cache等,那么它们有什么区别呢?每一种对象应用的环境是什么? 为了更清楚 ...

  2. Webpack学习错误解决笔记

    错误1:在用npm install 安装模块时,时常会出现没有以下类似的错误 解决方法:右键点击node_modules文件夹,选取属性,将文件夹只读选项去除 错误2:在学习到清理/dist文件夹这块 ...

  3. vs2010启动越来越慢解决方法

    自己用的电脑中vs2010启动总是越来越慢,耽误时间,用了下面的方法试了一下,效果还不错,如果你的vs2010也是,遇到这种问题不妨试一试: 1.重新设置了vs2010的环境(在vs2010命令提示符 ...

  4. Mac 10.12安装图片切换工具ArcSoft Photo+

    说明:Mac自带的图片切换不能连续切换,这款工具和美图看看差不多. 下载: (链接: https://pan.baidu.com/s/1i5rLYzr 密码: 49dp)

  5. python并发学习总结

    目录 一.理解操作系统 二.任务类型 三.Socket模块 四.一个简单的C/S程序 五.使用阻塞IO实现并发 方案一:阻塞IO+多进程 方案二:阻塞IO+多线程 阻塞IO模型的思考和总结 六.使用非 ...

  6. 【软件】chrome设置默认字体

    安装stylish插件 新建样式,加入代码 * { font-family: "Microsoft YaHei", "微软雅黑" !important; }

  7. VMware里Ubuntu-14.04-desktop的VMware Tools安装图文详解

    不多说,直接上干货!    前期步骤,请见如下 VMware里Ubuntukylin-14.04-desktop的VMware Tools安装图文详解 我这里,直接,是来说明,Ubuntu-14.04 ...

  8. Javac之关于方法的选择

    15.12. Method Invocation Expressions 15.12.1. Compile-Time Step 1: Determine Class or Interface to S ...

  9. guava学习:guava集合类型-Bimap

    学习guava让我惊喜的第二个接口就是:Bimap BiMap是一种特殊的映射其保持映射,同时确保没有重复的值是存在于该映射和一个值可以安全地用于获取键背面的倒数映射. 最近开发过程中,经常会有这种根 ...

  10. 关系型数据库MySQL多实例

    简介 MySQL数据库是一个中小型关系型数据库管理系统,软件开发者为瑞典MySQL AB公司.在2008年1月16号被Sun公司收购后Sun公司又被oracle公司收购.目前MySQL被广泛地应用在I ...