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 相关文章推荐
JavaScript打印网页指定区域的例子
May 03 Javascript
JavaScript中判断变量是数组、函数或是对象类型的方法
Feb 25 Javascript
jquery使用animate方法实现控制元素移动
Mar 27 Javascript
jQuery实现按钮的点击 全选/反选 单选框/复选框 文本框 表单验证
Jun 25 Javascript
jQuery+PHP实现可编辑表格字段内容并实时保存
Oct 09 Javascript
JQuery 的跨域方法推荐_可跨任何网站
May 18 Javascript
在微信、支付宝、百度钱包实现点击返回按钮关闭当前页面和窗口的方法
Aug 05 Javascript
AngularJS解决ng界面长表达式(ui-set)的方法分析
Nov 07 Javascript
jquery将标签元素的高设为屏幕的百分比
Apr 19 jQuery
vue-content-loader内容加载器的使用方法
Aug 05 Javascript
JavaScript函数、闭包、原型、面向对象学习笔记
Sep 06 Javascript
vue之组件内监控$store中定义变量的变化详解
Nov 08 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
php intval的测试代码发现问题
2008/07/27 PHP
php 读取shell管道传输过来的内容
2010/03/01 PHP
PHP中如何判断AJAX提交的数据
2012/02/05 PHP
PHP中ltrim与rtrim去除左右空格及特殊字符实例
2016/01/07 PHP
Laravel搭建后台登录系统步骤详解
2016/07/26 PHP
php中分页及SqlHelper类用法实例
2017/01/12 PHP
PHP中上传文件打印错误错误类型分析
2019/04/14 PHP
php报错502badgateway解决方法
2019/10/11 PHP
深入理解javascript原型链和继承
2014/09/23 Javascript
SublimeText自带格式化代码功能之reindent
2015/12/27 Javascript
js基于cookie方式记住返回页面用法示例
2016/05/27 Javascript
JavaScript和jquery获取父级元素、子级元素、兄弟元素的方法
2016/06/05 Javascript
JS实现十字坐标跟随鼠标效果
2017/12/25 Javascript
vue+element模态框中新增模态框和删除功能
2019/06/11 Javascript
vue 使用鼠标滚动加载数据的例子
2019/10/31 Javascript
nuxt引入组件和公共样式的操作
2020/11/05 Javascript
[38:38]完美世界DOTA2联赛PWL S3 access vs Rebirth 第二场 12.17
2020/12/18 DOTA
wxPython事件驱动实例详解
2014/09/28 Python
Python实现把utf-8格式的文件转换成gbk格式的文件
2015/01/22 Python
Python的SQLAlchemy框架使用入门
2015/04/29 Python
python的keyword模块用法实例分析
2015/06/30 Python
详解Python迭代和迭代器
2016/03/28 Python
通过python改变图片特定区域的颜色详解
2019/07/15 Python
Python实现性能自动化测试竟然如此简单
2019/07/30 Python
Python将列表中的元素转化为数字并排序的示例
2019/12/25 Python
python用tkinter实现一个简易能进行随机点名的界面
2020/09/27 Python
python Scrapy爬虫框架的使用
2021/01/21 Python
HTML5中如何显示视频呢 HTML5视频播放demo
2013/06/08 HTML / CSS
能否解释一下XSS cookie盗窃是什么意思
2012/06/02 面试题
采购部经理岗位职责
2014/02/10 职场文书
自我检讨报告
2015/01/28 职场文书
安徽导游词
2015/02/12 职场文书
学校捐款活动总结
2015/05/09 职场文书
楚门的世界观后感
2015/06/03 职场文书
《成长的天空》读后感3篇
2019/12/06 职场文书
Nginx代理同域名前后端分离项目的完整步骤
2021/03/31 Servers