Maison >interface Web >js tutoriel >Explication détaillée de l'utilisation du modèle de correspondance paresseux régulier (?)

Explication détaillée de l'utilisation du modèle de correspondance paresseux régulier (?)

php中世界最好的语言
php中世界最好的语言original
2018-03-30 11:34:391867parcourir

Cette fois, je vais vous apporter une explication détaillée de l'utilisation du mode de correspondance paresseux régulier (?). Quelles sont les précautions lors de l'utilisation du mode de correspondance paresseuse régulier (?). cas pratique, jetons un coup d'oeil.

Expression régulièreMode de correspondance paresseux :
Dans le chapitre sur le mode de correspondance gourmand, il a été dit que la nature humaine est avide, dans l'espoir d'obtenir plus d'argent, de statut et même de belles femmes , mais il y a aussi De nombreuses personnes stoïques n'ont besoin que de répondre à leurs besoins fondamentaux. Il existe également un tel principe de correspondance dans les expressions régulières. Introduisons-le ci-dessous.

1. Le concept du mode paresseux :

Ce mode est exactement l'opposé du mode gourmand Il correspond au moins de caractères possible pour satisfaire l'expression régulière, par exemple. exemple :

var str="axxyyzbdkb"; 
console.log(str.match(/a.*b/));

Le code ci-dessus est en mode gourmand, il peut donc correspondre à l'intégralité de la chaîne Modifions-le en mode de correspondance paresseux :

var str="axxyyzbdkb"; 
console.log(str.match(/a.*?b/));

. Le code ci-dessus est C'est une correspondance paresseuse. La méthode consiste à ajouter un point d'interrogation (?) après le quantificateur répété.
Le mode de correspondance paresseux consiste à faire correspondre le moins de caractères possible, mais doit respecter les règles de correspondance des expressions régulières. Par exemple, dans le code ci-dessus, * peut correspondre à plusieurs reprises à 0 ou plusieurs caractères ou sous-expressions précédents, mais les expressions régulières La fin. de la formule doit être b, afin que l'expression régulière puisse correspondre à axxyyzb dans la chaîne ci-dessus.

Le résumé est le suivant :

1. Ajoutez un point d'interrogation (?) après le quantificateur répété pour former une correspondance paresseuse.
2. La correspondance paresseuse correspondra au moins de caractères possible, mais l'ensemble du modèle de correspondance doit être satisfait.

2. Paresseux Qualificateur Liste :

语法结构 语义解释
*? 可以重复任意次,但是尽可能重复少的次数。
+? 可以重复1次或者任意多次,但是尽可能重复少的次数,不过最少次数是1。
?? 可以重复0次或1次,但尽可能少重复。
{n,m}? 可以重复n到m此,但尽可能少重复,最少匹配次数是n。
{n,}? 可以重复n次以上,但尽可能少重复,最少匹配n此。

首先引入一个介绍比较详细的网站

http://www.jb51.net/article/31491.htm

接下来是本人的简介

其实贪婪和惰性很容易理解,从字面意思我们就可以知道,所谓的"贪婪"的意思就是,如果符合要求就一直往后匹配,一直到无法匹配为止,这就是贪婪模式。所谓的惰性模式就是一旦匹配到合适的就结束,不在继续匹配下去了,下面我介绍几个例子来主要讲述一下。

首先讲述一下贪婪模式的标示符:+,?,*,{n},{n,},{n,m}.惰性模式:+?,??,*??,{n}?,{n,}?,{n,m}?;

例子一

var pattern=/8[a-zA-Z0-9]*7/;贪婪模式
var string="abc8defghij7klngon8qrstwxy7";

这时使用了贪婪模式*,表示8与8之间可有有任意多个字母,那这个正则先匹配第一个8,如果匹配到了后,就无限制的匹配后面的内容,只要后面的内容都满足[a-zA-Z0-9]就可以。一直匹配,匹配到不能再匹配为止,看紧接着后面的一个是不是7,如果不是那他就往前进一个(吐出一个看是不是7),如果不是再继续吐直到吐出7为止,然后匹配到的就是这之间的内容。所以结果匹配到的内容就是整条字符串。

var pattern=/8[a-zA-Z0-9]*?7/ig;惰性模式
var string="abc8defghij7klngon8qrstwxy7";

上面正则使用了惰性模式*?,此时匹配方式是这样的,先匹配一个8,然后在往后匹配一个字符看是不是符合[a-zA-Z0-9],如果符合,再去看紧接着后面的一个字符是不是7,如果是7就结束,如果不是就再往后匹配一个字符,看是不是符合[a-zA-Z0-9],如果符合,就再看紧接着后面的一个字符是不是7,如果是7就结束,否则,按照上面的方式依次循环下去,指导符合为止。

(2).贪婪和惰性模式还可以用另一种方式来表达。

例子二

var test="<img src="aaa/111.jpg"/><img src="aaa/112.jpg"/><img src="aaa/113.jpg"/>";
var pattern=/<img [^>]*\/>/ig;

这样也可以实现惰性模式,[^>]这个表示的就是在之间不能出现>,所以结果可以找寻每个标签。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

js里的正则实现数字每隔四位用空格分隔效果

在PHP里使用正则的效率 贪婪、非贪婪与回溯详解(附代码)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn