'<img abc 123 width="168" height="300"'.match(/(?=(width="))168/)
Je m'attends à extraire 123 situé dans width="123" d'une chaîne
Laissez-moi vous dire ce à quoi je peux penser en premier. Mais cette opération semble bizarre. Existe-t-il un moyen sympa
Utilisez le remplacement et récupérez-le dans le rappel ;
'<img abc 123 width="168" height="300"'.replace(/width="\d+"/,function(a){console.log(a)})
Ou comme @ars_qu
'<img abc 123 width="168" height="300"'.match(/width="\d+"/)[0].match(/\d+/)[0]
js prend mal en charge les assertions, utilisez simplement les groupes correspondants directement :
JS ne prend pas en charge la prélecture inversée
Il prend actuellement en charge la recherche directe pour les assertions de largeur nulle, c'est-à-dire la recherche de texte qui se termine par un mot spécifié (ou une autre condition). --JS est actuellement pris en charge ;
L'exigence dans votre question est de trouver le texte précédé du mot spécifié (ou d'autres conditions). --JS n'est actuellement pas pris en charge.
P.S. : Même si je le soutiens, votre écriture est fausse ! Si vous souhaitez trouver le nombre après la largeur, vous devez utiliser la recherche inversée. La bonne façon de l'écrire (en C# ou PHP) est
forward lookup/(?<=width)d+/
. . Notez le signe supplémentaire inférieur à./(?<=width)d+/
。 注意多了一个小于号。如果你想找width前面的数字,比如字符串是这样的"168width",这是用到的是正向预查,写法为
/d+(?=width)/
Si vous souhaitez trouver le nombre devant la largeur, par exemple, la chaîne ressemble à "168width", cela utilise, qui s'écrit
/d+(?=width)/
.Pratique standard - Capture de groupes
🎜L'utilisation de la capture régulière est la meilleure méthode dans votre scénario. 🎜Tu ne peux pas simplement utiliser width=".*?", puis faire correspondre les nombres ?
js ne semble pas prendre en charge certaines expressions régulières, telles que l'assertion de largeur nulle....