JS 学习总结之正则表达式的懒惰性和贪婪性


Posted in Javascript onJuly 03, 2017

exec - > 正则的捕获

每一次捕获的时候都是先进行默认的匹配,如果没有匹配成功的,捕获的结果是null;只有有匹配的内容我们才能捕获到;

捕获的内容格式

1、捕获到的内容是一个数组,数组中的第一项是当前正则捕获的内容

index:捕获内容在字符串中开始的索引位置

input:捕获的原始字符串

var reg = /\d+/;
var str = 'woshi2016ni2017';
var res = reg.exec(str);
console.log(res) // ['2016',index:5,input:'woshi2016ni2017']
//第二次通过exec捕获的内容还是第一个"2016"
var res = reg.exec(str);
console.log(res) // ['2016',index:5,input:'woshi2016ni2017']

2、正则捕获的特点

1)、懒惰性->每一次执行exec只捕获第一个匹配的内容,在不进行任何处理的情况下,在执行多次捕获,捕获的还是第一个匹配的内容。

lastIndex:是正则每一次捕获在字符串中开始查找的位置,默认值为0

2)、如何解决懒惰性?在正则的末尾加一个修饰符"g"

修饰符:g、i、m

global(g):全局匹配

ignoreCase(i):忽略大小写匹配

multiline(m):多行匹配

var reg = /\d/g;
var str = 'woshi2016ni2017';
console.log(reg.lastIndex)
console.log(reg.exec(str))

 

原理:加了全局修饰符g,正则每一次捕获结束后,我们的lastIndex的值都变成了最新的值,下一次捕获从最新的位置开始查找,这样就可以把所有需要捕获的内容都获取到了

3)、自己编写程序获取正则捕获的所有的内容(一定不要忘了加g)

var reg = /\d+/g;
    var str = 'aswofde2015xsewde2016awdefer2017';
    var ary = [];
    var res = reg.exec(str);
    while(res){
      ary.push(res[0])
      res = reg.exec(str);
    }
    console.log(ary)//[2015,2016,2017]

4)、贪婪性   正则的每一次捕获都是按照匹配最长的结果捕获的,例如:2符合正则、2015也符合正则,我们默认捕获的是2015

5)、如何解决正则的贪婪性 ->在量词元字符后面添加一个?即可 

var reg = /\d+?/g;
    var str = 'aswofde2015xsewde2016awdefer2017';
    console.log(reg.exec(str));

?在正则中有很多的作用:

放在一个普通的元字符后面代表出现0-1次 /\d?/  ->数字可能出现也可能不出现

放在一个量词的元字符后面是取消捕获时候的贪婪性

3、字符串中的match方法->把所有和正则匹配的字符都获取到

var reg = /\d+?/g;
    var str = 'aswofde2015xsewde2016awdefer2017';
    var ary = str.match(reg);//[2,0,1,5,2,0,1,6,2,0,1,7]

虽然在当前的情况下match比我们的exec更加的简便一些,但是match中存在一些自己处理不了的问题,在分组的捕获的情况下,match只能捕获大正则匹配的内容,而对于小正则捕获的内容是无法获取的

以上所述是小编给大家介绍的JS 学习总结之正则表达式的懒惰性和贪婪性,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
ExtJS 工具栏 分页事件参数
Mar 05 Javascript
jquery获取input的value问题说明
Aug 19 Javascript
js中widow.open()方法使用详解
Jul 30 Javascript
让jQuery Mobile不显示讨厌loading界面的方法
Feb 19 Javascript
微信小程序 动态绑定数据及动态事件处理
Mar 14 Javascript
vue 和vue-touch 实现移动端左右导航效果(仿京东移动站导航)
Apr 22 Javascript
layui表格实现代码
May 20 Javascript
vue-cli单页应用改成多页应用配置详解
Jul 14 Javascript
vue-baidu-map 进入页面自动定位的解决方案(推荐)
Apr 28 Javascript
vue-cli3 从搭建到优化的详细步骤
Jan 20 Javascript
如何通过JS实现转码与解码
Feb 21 Javascript
Vue实现手机计算器
Aug 17 Javascript
JavaScript之DOM插入更新删除_动力节点Java学院整理
Jul 03 #Javascript
微信小程序开发中的疑问解答汇总
Jul 03 #Javascript
JavaScript之promise_动力节点Java学院整理
Jul 03 #Javascript
JavaScript之DOM_动力节点Java学院整理
Jul 03 #Javascript
javaScript中封装的各种写法示例(推荐)
Jul 03 #Javascript
JavaScript之class继承_动力节点Java学院整理
Jul 03 #Javascript
JavaScript之浏览器对象_动力节点Java学院整理
Jul 03 #Javascript
You might like
延长phpmyadmin登录时间的方法
2011/02/06 PHP
使用PHP获取当前url路径的函数以及服务器变量
2013/06/29 PHP
thinkPHP3.2简单实现文件上传的方法
2016/05/16 PHP
ThinkPHP实现的rsa非对称加密类示例
2018/05/29 PHP
关于Laravel参数验证的一些疑与惑
2019/11/19 PHP
Javascript 不能释放内存.
2006/09/07 Javascript
javascript引用对象的方法代码
2007/08/13 Javascript
javascript权威指南 学习笔记之javascript数据类型
2011/09/24 Javascript
js异常捕获方法介绍
2013/04/10 Javascript
JS.getTextContent(element,preformatted)使用介绍
2013/09/21 Javascript
动态的创建一个元素createElement及删除一个元素
2014/01/24 Javascript
js校验表单后提交表单的三种方法总结
2014/02/28 Javascript
js计算文本框输入的字符数
2015/10/23 Javascript
jquery中ajax跨域方法实例分析
2015/12/18 Javascript
基于javascript实现图片预加载
2016/01/05 Javascript
JS中改变this指向的方法(call和apply、bind)
2016/03/26 Javascript
JS实现对中文字符串进行utf-8的Base64编码的方法(使其与Java编码相同)
2016/06/21 Javascript
移动端界面的适配
2017/01/11 Javascript
浅谈JS封闭函数、闭包、内置对象
2017/07/18 Javascript
浅谈angular4.0中路由传递参数、获取参数最nice的写法
2018/03/12 Javascript
在vue中读取本地Json文件的方法
2018/09/06 Javascript
微信小程序系列之自定义顶部导航功能
2019/05/21 Javascript
在Python3中初学者应会的一些基本的提升效率的小技巧
2015/03/31 Python
Python实现简易端口扫描器代码实例
2017/03/15 Python
tensorflow实现简单的卷积神经网络
2018/05/24 Python
对python字典过滤条件的实例详解
2019/01/22 Python
Python分支语句与循环语句应用实例分析
2019/05/07 Python
python3中sorted函数里cmp参数改变详解
2020/03/12 Python
Marlies Dekkers内衣美国官方网上商店:高端内衣品牌
2018/11/12 全球购物
2014年师德师风自我剖析材料
2014/09/27 职场文书
教师三严三实学习心得体会
2014/10/11 职场文书
求职简历自我评价怎么写
2015/03/10 职场文书
劳动合同变更协议书范本
2019/04/18 职场文书
利用Pycharm连接服务器的全过程记录
2021/07/01 Python
IIS服务器中设置HTTP重定向访问HTTPS
2022/04/29 Servers
向Spring IOC 容器动态注册bean实现方式
2022/07/15 Java/Android