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 相关文章推荐
自己的js工具 Event封装
Aug 21 Javascript
JavaScript Event学习第十一章 按键的检测
Feb 10 Javascript
JavaScript的常见兼容问题及相关解决方法(chrome/IE/firefox)
Dec 31 Javascript
js使用for循环及if语句判断多个一样的name
Sep 09 Javascript
举例详解JavaScript中Promise的使用
Jun 24 Javascript
vue2 如何实现div contenteditable=“true”(类似于v-model)的效果
Feb 08 Javascript
老生常谈Bootstrap媒体对象
Jul 06 Javascript
js+css实现打字效果
Jun 24 Javascript
详解vuex的简单todolist例子
Jul 14 Javascript
在vue项目中引用Antv G2,以饼图为例讲解
Oct 28 Javascript
Vue实现摇一摇功能(兼容ios13.3以上)
Jan 26 Vue.js
vue2的 router在使用过程中遇到的一些问题
Apr 13 Vue.js
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
php获取用户浏览器版本的方法
2015/01/03 PHP
PHP中$_SERVER使用说明
2015/07/05 PHP
php验证码实现代码(3种)
2015/09/07 PHP
一个简单安全的PHP验证码类、PHP验证码
2016/09/24 PHP
PHP二维数组去重实例分析
2016/11/18 PHP
cnblogs TagCloud基于jquery的实现代码
2010/06/11 Javascript
JS按位非(~)运算符与~~运算符的理解分析
2011/07/31 Javascript
ajax java 实现自动完成功能
2012/12/19 Javascript
js使用removeChild方法动态删除div元素
2014/08/01 Javascript
使用jquery菜单插件HoverTree仿京东无限级菜单
2014/12/18 Javascript
通过实例理解javascript中没有函数重载的概念
2015/06/03 Javascript
jQuery实现自定义checkbox和radio样式
2015/07/13 Javascript
Bootstrap导航条可点击和鼠标悬停显示下拉菜单的实现代码
2016/06/23 Javascript
jquery判断iPhone、Android设备类型
2016/09/14 Javascript
vue利用better-scroll实现轮播图与页面滚动详解
2017/10/20 Javascript
nuxt中使用路由守卫的方法步骤
2019/01/27 Javascript
基于vue通用表单解决方案的思考与分析
2019/03/16 Javascript
JS面向对象编程实现的拖拽功能案例详解
2020/03/03 Javascript
[00:32]DOTA2上海特级锦标赛 Ehome战队宣传片
2016/03/03 DOTA
python 实现归并排序算法
2012/06/05 Python
浅谈Python类里的__init__方法函数,Python类的构造函数
2016/12/10 Python
python时间日期函数与利用pandas进行时间序列处理详解
2018/03/13 Python
python 使用poster模块进行http方式的文件传输到服务器的方法
2019/01/15 Python
PyCharm 创建指定版本的 Django(超详图解教程)
2019/06/18 Python
python动态规划算法实例详解
2020/11/22 Python
Python爬虫自动化获取华图和粉笔网站的错题(推荐)
2021/01/08 Python
浅谈Html5中视频 音频标签 进度条的问题
2016/07/26 HTML / CSS
YOOX台湾:意大利奢侈品电商
2018/10/13 全球购物
Linux上比较文件的命令都有哪些
2013/09/28 面试题
伊琍体标语
2014/06/25 职场文书
小学师德师风整改措施
2014/10/27 职场文书
公司离职证明标准格式
2014/11/18 职场文书
校运会宣传稿大全
2015/07/23 职场文书
学习经验交流会策划书
2015/11/02 职场文书
使用qt quick-ListView仿微信好友列表和聊天列表的示例代码
2021/06/13 Python
Python字符串格式化方式
2022/04/07 Python