Heim  >  Artikel  >  Web-Frontend  >  Vertiefendes Verständnis der JS-Testmethode für reguläre Ausdrücke und ihrer Fallstricke

Vertiefendes Verständnis der JS-Testmethode für reguläre Ausdrücke und ihrer Fallstricke

不言
不言Original
2018-07-11 09:55:412300Durchsuche

Dieser Artikel stellt hauptsächlich die Testmethode und ihre Fallen für ein detailliertes Verständnis der regulären JS-Ausdrücke vor. Jetzt kann ich sie mit Ihnen teilen.

Test Methode

Einführung in die Testmethode

RegExp.prototype.test(str)

Die Testmethode wird verwendet, um zu testen, ob im String-Parameter eine Zeichenfolge vorhanden ist, die dem regulären Ausdrucksmuster entspricht

Verwendung der Testmethode

let reg = /\w/

reg.test('a')       // true

reg.test('$')       // false

Aus den Ergebnissen ist ersichtlich, dass der Testzeichenfolgenparameter, wenn er eine Zeichenfolge enthält, die dem regulären Ausdrucksmuster entspricht, „true“ zurückgibt, andernfalls „false“ zurückgibt

Die Fallstricke der Testmethode

Wenn der reguläre Ausdruck verwendet wird und der globale Abgleich deaktiviert ist, tritt bei der Testmethode das folgende seltsame Phänomen auf:

let reg = /\w/g

reg.test('ab')      // true

reg.test('ab')      // true

reg.test('ab')      // false

reg.test('ab')      // true

Sie können sehen, dass die dritte Übereinstimmungsrückgabe in jeder Runde wahr wird. aber stimmt nicht alles mit reg überein, sollte die Rückgabe true zurückgeben. Der Grund liegt im im vorherigen Abschnitt erwähnten lastIndex-Attribut. ab

Wir können die lastIndex-Methode ausprobieren, die jedes Mal, wenn wir die Testmethode ausführen, reg ausgibt:

let reg = /\w/g
reg.lastIndex       // 0

reg.test('ab')      // true
reg.lastIndex       // 1

reg.test('ab')      // true
reg.lastIndex       // 2

reg.test('ab')      // false
reg.lastIndex       // 0

reg.test('ab')      // true
reg.lastIndex       // 1

Sehen Sie sich die Ergebnisse an und erinnern Sie sich dann an die Definition von lastIndex. Sie werden den Grund verstehen.

Das lastIndex-Attribut ist die letzte Ziffer des letzten Zeichens, mit dem der aktuelle Ausdruck übereinstimmt, und wird verwendet, um die Startposition der nächsten Übereinstimmung anzugeben.

Wenn Sie in den globalen Modus für reguläre Ausdrücke wechseln, beginnt die Testmethode jedes Mal bei lastIndex und stimmt mit der Teilzeichenfolge ab lastIndex überein. Wenn beispielsweise im Beispiel die Testmethode zum zweiten Mal ausgeführt wird, hat sich lastIndex in 2 geändert und die Teilzeichenfolge ist leer, sodass reg nicht mit ihr übereinstimmen kann. Da der Teilstring-Abgleich fehlschlägt, gibt die Testmethode „false“ zurück, setzt das lastIndex-Attribut auf 0 und startet die Schleife neu.

Methoden zur Vermeidung von Fallstricken im Test

Die erste Methode: Die Testmethode selbst wird verwendet, um zu testen, ob eine Zeichenfolge vorhanden ist, die dem regulären Muster entspricht. Der Zweck kann ohne Verwendung des globalen Musters erreicht werden , also die erste Methode Eine Möglichkeit besteht darin, den globalen Modus nicht zu verwenden.

Die zweite Methode: Speichern Sie die reguläre Objektinstanz nicht in der Variablen und rufen Sie die Testmethode jedes Mal direkt mit der regulären Objektinstanz auf. Diese Methode verbraucht jedoch Speicher und wird theoretisch nicht empfohlen.

Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, er wird für das Studium aller hilfreich sein. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website.

Verwandte Empfehlungen:

Vertiefendes Verständnis der Analyse von REGEXP-Objektattributen von regulären JS-Ausdrücken

In- tiefes Verständnis der regulären JS-Ausdrücke Analyse der Gruppierung von Formeln

Tiefe Verständnis der Analyse des Greedy-Modus und des Non-Greedy-Modus von regulären JS-Ausdrücken

Das obige ist der detaillierte Inhalt vonVertiefendes Verständnis der JS-Testmethode für reguläre Ausdrücke und ihrer Fallstricke. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn