Maison >interface Web >js tutoriel >Pourquoi mon modèle d'expression régulière échoue-t-il avec l'indicateur \'v\' dans l'attribut de modèle HTML ?
Validité des modèles d'expressions régulières avec des indicateurs Unicode
Problèmes avec les modèles RegExp dans l'attribut de modèle HTML
Lorsque vous utilisez un modèle d'expression régulière avec l'indicateur « v » dans un attribut de modèle HTML, vous pouvez rencontrer une erreur « SyntaxError ». Cette erreur se produit car l'indicateur 'v' est automatiquement appliqué lors de la compilation du modèle dans un objet RegExp.
Soustraction et échappement de classe de caractères
L'indicateur 'v' introduit des règles d'échappement plus strictes, qui n'autorisent pas le caractère littéral « - » à la fin d'une classe de caractères. Ceci contraste avec le drapeau « u », où il n'y a pas de telle restriction.
Modèle Regex avec les drapeaux « u » et « v »
Considérez ce qui suit modèle regex :
^[a-zA-Z0-9+_.-]+@[a-zA-Z0-9]+\.[a-zA-Z0-9]+$
Avec le drapeau 'u' appliqué :
<code class="js">console.log(/^[a-zA-Z0-9+_.-]+@[a-zA-Z0-9]+\.[a-zA-Z0-9]+$/u.test("[email protected]")); // true</code>
Avec le drapeau 'v' appliqué (automatiquement dans l'attribut de motif HTML) :
<code class="js">console.log(/^[a-zA-Z0-9+_.\-]+@[a-zA-Z0-9]+\.[a-zA-Z0-9]+$/v.test("[email protected]")); // SyntaxError</code>
Résolution
Pour résoudre l'erreur, vous devez échapper le caractère '-' à la fin de la classe de caractères. Voici le modèle corrigé :
^[a-zA-Z0-9+_.-]+@[a-zA-Z0-9]+\.[a-zA-Z0-9]+$
Ce modèle devrait maintenant fonctionner correctement avec et sans le drapeau 'v'.
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!