js正则表达式惰性匹配和贪婪匹配用法分析


Posted in Javascript onDecember 26, 2016

本文实例讲述了js正则表达式惰性匹配和贪婪匹配用法。分享给大家供大家参考,具体如下:

在讲贪婪模式和惰性模式之前,先回顾一下JS正则基础:

写法基础:

①不需要双引号,直接用//包含 => /wehfwue123123/.test();

②反斜杠\表示转义 =>/\.jpg$/

③用法基础:.test(str);

语法:

①锚点类

/^a/=>以"a"开头

/\.jpg$/=>以".jpg"结尾

②字符类

[abc]:a或b或c

[0-9]:一个数字

[a-z]:一个字母

.    :任意字符

③元字符

^:在[]里面用表示非,在[]外面用表示开头

\d:[0-9]

\s:空白符

\w:[A-Za-z0-9_]

\D:[^\d]-非数字

\S:非空白符

④量词

{m,n}:m到n次

元字符表示:

*:{0,}

?:{0,1}

+:{1,}

难点:贪婪模式/惰性模式

贪婪模式——在匹配成功的前提下,尽可能多的去匹配

惰性模式——在匹配成功的前提下,尽可能少的去匹配

解释一:码文并茂

使用正则表达式中的贪婪、惰性的量词可以控制表达式匹配过程,我们知道量词?、*、+的意义,可以指定相关模式出现的次数,默认的情况下我们使用的是贪婪量词,它的匹配过程是从整个字符串开始查看,如果不匹配就去掉最后一个,再看看是否匹配,如此循环一直到匹配或字符串空为止,如:

vars ="abbbaabbbaaabbb1234";
varre1=/.*bbb/g;//*是贪婪量词
re1.test(s);

这个匹配过程将从整个字符串开始:

re1.test("abbbaabbbaaabbb1234");//false ,则去掉最后一个字符4再继续
re1.test("abbbaabbbaaabbb123");//false ,则去掉最后一个字符3再继续
re1.test("abbbaabbbaaabbb12");//false ,则去掉最后一个字符2再继续
re1.test("abbbaabbbaaabbb1");//false ,则去掉最后一个字符1再继续
re1.test("abbbaabbbaaabbb");//true ,结束

在贪婪量词的后面加多一个?就变成了惰性量词,它的匹配过程相反,是从前面第一个开始,不匹配则加一个,如此循环直到字符串结束,以上面的为例子。

vars ="abbbaabbbaaabbb1234";
varre1=/.*?bbb/g;//*?是惰性量词
re1.test(s);

它的匹配过程如下:

re1.test("a");//false, 再加一个
re1.test("ab");//false, 再加一个
re1.test("abb");//false, 再加一个
re1.test("abbb");//true, 匹配了,保存这个结果,再从下一个开始
re1.test("a");//false, 再加一个
re1.test("aa");//false, 再加一个
re1.test("aab");//false, 再加一个
re1.test("aabb");//false, 再加一个
re1.test("aabbb");//true, 匹配了,保存这个结果,再从下一个开始

小结:

默认的贪婪匹配是从后往前匹配,最大长度的匹配,惰性匹配就是在量词后面加个?从字符串的前面开始匹配,最小长度的匹配

Javascript 相关文章推荐
解析JavaScript中的标签语句
Jun 19 Javascript
各种常用的JS函数整理
Oct 25 Javascript
javascript的回调函数应用示例
Feb 20 Javascript
JS高级调试技巧:捕获和分析 JavaScript Error详解
Mar 16 Javascript
jquery中$each()方法的使用指南
Apr 30 Javascript
基于jQuery实现仿百度首页选项卡切换效果
May 29 Javascript
json的使用小结
Jun 08 Javascript
利用Angularjs和bootstrap实现购物车功能
Aug 31 Javascript
JS 在数组指定位置插入/删除数据的方法
Jan 12 Javascript
微信小程序实战之顶部导航栏(选项卡)(1)
Jun 19 Javascript
20170918 前端开发周报之JS前端开发必看
Sep 18 Javascript
vuex 使用文档小结篇
Jan 11 Javascript
Bootstrap的modal拖动效果
Dec 25 #Javascript
原生ajax处理json格式数据的实例代码
Dec 25 #Javascript
JS异步文件分片断点上传的实现思路
Dec 25 #Javascript
BootStrop前端框架入门教程详解
Dec 25 #Javascript
半个小时学json(json传递示例)
Dec 25 #Javascript
在DWR中实现直接获取一个JAVA类的返回值的两种方法
Dec 25 #Javascript
JS如何生成一个不重复的ID的函数
Dec 25 #Javascript
You might like
9段PHP实用功能的代码推荐
2014/10/14 PHP
PHP实现适用于自定义的验证码类
2016/06/15 PHP
php适配器模式简单应用示例
2019/10/23 PHP
javascript之函数直接量(function(){})()
2007/06/29 Javascript
jquery 最简单的属性菜单
2009/10/08 Javascript
js操作时间(年-月-日 时-分-秒 星期几)
2010/06/20 Javascript
jQuery 操作option的实现代码
2011/03/03 Javascript
js调用后台servlet方法实例
2013/06/09 Javascript
javascript中处理时间戳为日期格式的方法
2014/01/02 Javascript
jQuery晃动层特效实现方法
2015/03/09 Javascript
js window对象属性和方法相关资料整理
2015/11/11 Javascript
Vue.js组件使用开发实例教程
2016/11/01 Javascript
JS高级运动实例分析
2016/12/20 Javascript
详解从新建vue项目到引入组件Element的方法
2017/08/29 Javascript
vue 粒子特效的示例代码
2017/09/19 Javascript
JavaScript实现左右滚动电影画布
2020/02/06 Javascript
解决vue+elementui项目打包后样式变化问题
2020/08/03 Javascript
django数据库migrate失败的解决方法解析
2018/02/08 Python
python去掉空白行的多种实现代码
2018/03/19 Python
python 获取当天凌晨零点的时间戳方法
2018/05/22 Python
Python3中的最大整数和最大浮点数实例
2019/07/09 Python
解决Django加载静态资源失败的问题
2019/07/28 Python
解决Pycharm 包已经下载,但是运行代码提示找不到模块的问题
2019/08/31 Python
python nmap实现端口扫描器教程
2020/05/28 Python
python中not、and和or的优先级与详细用法介绍
2020/11/03 Python
美国内衣第一品牌:Hanes(恒适)
2016/07/29 全球购物
New Era英国官网:美国棒球帽品牌
2018/03/21 全球购物
丝芙兰新加坡官网:Sephora新加坡
2018/12/04 全球购物
春风行动实施方案
2014/03/28 职场文书
商务助理求职信范文
2014/04/20 职场文书
大四学生个人总结
2015/02/15 职场文书
幼儿园六一儿童节演讲稿
2015/03/19 职场文书
办公室岗位职责范本
2015/04/11 职场文书
vue中data改变后让视图同步更新的方法
2021/03/29 Vue.js
Go语言实现一个简单的并发聊天室的项目实战
2022/03/18 Golang
Python实现双向链表基本操作
2022/05/25 Python