正则表达式中的正向预查和负向预查实例分析
本文实例讲述了正则表达式中的正向预查和负向预查。分享给大家供大家参考。具体分析如下:
这里先来看一个例子,再来解释什么是正向预查。
例子:有一段内容为"coming soon,going gogogo",要求把com和go查找出来。代码如下:
代码如下:
<html> <head> <script type="text/javascript"> //正向预查 function t1(){ var con = document.getElementsByName('content')[0].value; var reg = /\b[\w]+(?=ing\b)/g;//匹配带ing的单词,但是不要ing。注意:如果ing后不加\b,类似于goingabc也会匹配。 alert(con.match(reg)); } </script> </head> <body> <textarea rows="5" cols="30" name="content"></textarea><br /> <button onclick="t1();">正则预查</button><br /> </body> </html>
以上面的实例来讲解正向预查:先查出边界,再找到与[\w]+匹配的字,(?=ing)表示先向后探测,看看有没有ing。如果有,则把前面的匹配出来;如果没有,则光标往后移一位,继续探测。这个过程就是正向预查:预先判断为某个值 。
所谓负向预查,就是预先判断不为某个值。文本框输入内容为"win7,winxp,win95,win98,win2003"
代码如下:
<html> <head> <script type="text/javascript"> //正向预查 function t1(){ var con = document.getElementsByName('content')[0].value; var reg = /\bwin(?!95\b)/g;// alert(con.match(reg)); } </script> </head> <body> <textarea rows="5" cols="30" name="content"></textarea><br /> <button onclick="t1();">正则预查</button><br /> </body> </html>
上面两个例子是从前往后正向/负向预查----相关信息百度搜索"零宽断言"。JS不支持向前正向/负向预查,而PHP支持。
希望本文所述对大家的正则表达式学习有所帮助。
相关推荐
wangzhaotongalex 2020-10-20
wyq 2020-11-11
TLROJE 2020-10-26
风雨断肠人 2020-10-13
duanqingfeng 2020-09-29
rechanel 2020-11-16
cshanzhizi 2020-10-16
luofuIT成长记录 2020-09-22
phphub 2020-09-10
taomengxing 2020-09-07
MaggieRose 2020-08-19
flyingssky 2020-08-18
山水沐光 2020-08-18
jyj00 2020-08-15
AHuqihua 2020-08-09
山水沐光 2020-08-03