


Analyse de l'utilisation du modificateur d'expression régulière JS global(/g)
L'exemple de cet article décrit l'utilisation du modificateur d'expression régulière JS global(/g). Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :
/g le modificateur représente la correspondance globale, recherchant toutes les correspondances au lieu de s'arrêter après avoir trouvé la première correspondance. Regardons d'abord un morceau de code classique :
var str = "123#abc"; var noglobal = /abc/i;//非全局匹配模式 console.log(re.test(str)); //输出ture console.log(re.test(str)); //输出ture console.log(re.test(str)); //输出ture console.log(re.test(str)); //输出ture var re = /abc/ig;//全局匹配 console.log(re.test(str)); //输出ture console.log(re.test(str)); //输出false console.log(re.test(str)); //输出ture console.log(re.test(str)); //输出false
Vous pouvez voir : Lorsque vous utilisez le mode /g, les résultats de sortie de RegExp.test() sont exécutés plusieurs fois. Il y aura une différence.
Lors de la création d'un objet d'expression régulière, si l'identifiant "g" est utilisé ou si sa valeur d'attribut ?global est définie sur true, l'objet d'expression régulière nouvellement créé utilisera le modèle pour correspondre. Les chaînes correspondent globalement. En mode de correspondance globale, plusieurs correspondances peuvent être effectuées sur la chaîne spécifiée à trouver. Chaque correspondance utilise la valeur de l'attribut lastIndex de l'objet régulier actuel comme position de départ pour lancer la recherche dans la chaîne cible. La valeur initiale de l'attribut lastIndex est 0. Une fois qu'un élément correspondant est trouvé, la valeur de lastIndex est réinitialisée à l'index de position du caractère suivant du contenu correspondant dans la chaîne, qui est utilisé pour identifier la position où commencer la recherche. la prochaine fois qu'un match sera joué. Si aucun élément correspondant n'est trouvé, la valeur de lastIndex sera définie sur 0. Lorsque l'indicateur de correspondance globale de l'objet normal n'est pas défini, la valeur de l'attribut lastIndex est toujours 0 et chaque fois qu'une correspondance est effectuée, seul le premier élément correspondant de la chaîne est trouvé.
Vous pouvez vérifier les performances de lastIndex en mode /g grâce au code suivant :
var str = "012345678901234567890123456789"; var re = /123/g; console.log(re.lastIndex); //输出0,正则表达式刚开始创建 console.log(re.test(str)); //输出ture console.log(re.lastIndex); //输出4 console.log(re.test(str)); //输出true console.log(re.lastIndex); //输出14 console.log(re.test(str)); //输出ture console.log(re.lastIndex); //输出24 console.log(re.test(str)); //输出false console.log(re.lastIndex); //输出0,没有找到匹配项被重置
Ci-dessus nous avons vu l'impact du mode /g sur la fonction RegExp.test(), Voyons maintenant l'impact sur la fonction RegExp.exec(). RegExp.exec() renvoie un tableau contenant les résultats correspondants. Si aucune correspondance n'est trouvée, la valeur de retour est nulle.
var str = "012345678901234567890123456789"; var re = /abc/; //exec没有找到匹配 console.log(re.exec(str));//null console.log(re.lastIndex);//0
var str = "012345678901234567890123456789"; var re = /123/; var resultArray = re.exec(str); console.log(resultArray[0]);//匹配结果123 console.log(resultArray.input);//目标字符串str console.log(resultArray.index);//匹配结果在原始字符串str中的索引
Pour la méthode RegExp.exec, si g n'est pas ajouté, seule la première correspondance sera renvoyée, quel que soit le nombre de fois il est exécuté ; si g est ajouté, la première exécution renverra également la première correspondance, et la deuxième exécution renverra la deuxième correspondance, et ainsi de suite.
var str = "012345678901234567890123456789"; var re = /123/; var globalre = /123/g; //非全局匹配 var resultArray = re.exec(str); console.log(resultArray[0]);//输出123 console.log(resultArray.index);//输出1 console.log(globalre.lastIndex);//输出0 var resultArray = re.exec(str); console.log(resultArray[0]);//输出123 console.log(resultArray.index);//输出1 console.log(globalre.lastIndex);//输出0 //全局匹配 var resultArray = globalre.exec(str); console.log(resultArray[0]);//输出123 console.log(resultArray.index);//输出1 console.log(globalre.lastIndex);//输出4 var resultArray = globalre.exec(str); console.log(resultArray[0]);//输出123 console.log(resultArray.index);//输出11 console.log(globalre.lastIndex);//输出14
Lors de l'utilisation du mode de correspondance /g, nous pouvons obtenir toutes les correspondances via une boucle.
var str = "012345678901234567890123456789"; var globalre = /123/g; //循环遍历,获取所有匹配 var result = null; while ((result = globalre.exec(str)) != null) { console.log(result[0]); console.log(globalre.lastIndex); }
J'espère que cet article sera utile à tout le monde dans la programmation JavaScript.
Pour plus d'articles liés à l'analyse de l'utilisation du modificateur d'expression régulière JS global(/g), veuillez faire attention au site Web PHP chinois !

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

L'article discute de la création, de la publication et du maintien des bibliothèques JavaScript, en se concentrant sur la planification, le développement, les tests, la documentation et les stratégies de promotion.

L'article traite des stratégies pour optimiser les performances JavaScript dans les navigateurs, en nous concentrant sur la réduction du temps d'exécution et la minimisation de l'impact sur la vitesse de chargement de la page.

Des questions et des solutions fréquemment posées pour l'impression de billets thermiques frontaux pour le développement frontal, l'impression de billets est une exigence commune. Cependant, de nombreux développeurs mettent en œuvre ...

L'article traite du débogage efficace de JavaScript à l'aide d'outils de développeur de navigateur, de se concentrer sur la définition des points d'arrêt, de l'utilisation de la console et d'analyser les performances.

L'article explique comment utiliser les cartes source pour déboguer JavaScript minifiée en le mappant au code d'origine. Il discute de l'activation des cartes source, de la définition de points d'arrêt et de l'utilisation d'outils comme Chrome Devtools et WebPack.

Une fois que vous avez maîtrisé le didacticiel TypeScript de niveau d'entrée, vous devriez être en mesure d'écrire votre propre code dans un IDE qui prend en charge TypeScript et de le compiler en JavaScript. Ce tutoriel plongera dans divers types de données dans TypeScript. JavaScript a sept types de données: null, non défini, booléen, numéro, chaîne, symbole (introduit par ES6) et objet. TypeScript définit plus de types sur cette base, et ce tutoriel les couvrira tous en détail. Type de données nuls Comme javascript, null en typeScript

Cet article explore une utilisation efficace du cadre de collections de Java. Il met l'accent sur le choix des collections appropriées (liste, set, map, file d'attente) en fonction de la structure des données, des besoins en performances et de la sécurité des threads. Optimisation de l'utilisation de la collection grâce à

Ce tutoriel expliquera comment créer des graphiques à tarte, anneaux et bulles à l'aide de chart.js. Auparavant, nous avons appris quatre types de graphiques de graphique. Créer des graphiques à tarte et à anneaux Les graphiques à tarte et les graphiques d'anneaux sont idéaux pour montrer les proportions d'un tout divisé en différentes parties. Par exemple, un graphique à secteurs peut être utilisé pour montrer le pourcentage de lions mâles, de lions féminins et de jeunes lions dans un safari, ou le pourcentage de votes que différents candidats reçoivent lors des élections. Les graphiques à tarte ne conviennent que pour comparer des paramètres ou des ensembles de données uniques. Il convient de noter que le graphique à tarte ne peut pas dessiner des entités avec une valeur nulle car l'angle du ventilateur dans le graphique à tarte dépend de la taille numérique du point de données. Cela signifie toute entité avec une proportion nulle
