Falsche Ergebnisse von Regexp mit Global Flag
Im bereitgestellten Code wird der reguläre Ausdruck new RegExp(query, 'gi') verwendet mit den Flags g (global) und i (ohne Berücksichtigung der Groß- und Kleinschreibung). Das Ergebnis ist jedoch unerwartet: [wahr, falsch].
Das globale Flag verstehen
Das g-Flag in einem RegExp-Objekt steuert das Verhalten von test() Verfahren. Wenn diese Option festgelegt ist, sucht test() wiederholt nach dem Muster in der Zeichenfolge, beginnend dort, wo die vorherige Übereinstimmung endete. Dies wird als „Klebrigkeit“ bezeichnet.
Falsche Ergebniserklärung
Im Beispiel findet der erste Aufruf von re.test('Foo Bar') die Übereinstimmung „ Foo B.“ Da das g-Flag gesetzt ist, wird lastIndex auf die Position nach „Foo B“ aktualisiert. Das bedeutet, dass der nachfolgende Aufruf von re.test('Foo Bar') die Suche ab der Position nach „Foo B“ beginnt. Es wird keine Übereinstimmung gefunden, was zu einem falschen Ergebnis führt.
Beispiel mit Sticky Flag
Bedenken Sie den folgenden Code:
var reg = /^a$/g; for(i = 0; i++ < 10;) console.log(reg.test("a"));
Dieser Code wird gedruckt 10 Mal „wahr“. Da reg das g-Flag hat, bleibt es bei der letzten Übereinstimmung und testet wiederholt „a“ von der Position nach der vorherigen Übereinstimmung bis zum Ende der Zeichenfolge.
Lösung
Um den ursprünglichen Code zu korrigieren, setzen Sie re.lastIndex vor jedem test()-Aufruf auf 0 zurück:
var query = 'Foo B'; var re = new RegExp(query, 'gi'); result.push(re.test('Foo Bar')); re.lastIndex = 0; result.push(re.test('Foo Bar'));
Dadurch wird sichergestellt, dass die Suche am Anfang der Zeichenfolge beginnt Jeder test()-Aufruf liefert das korrekte Ergebnis von [true, true].
Das obige ist der detaillierte Inhalt vonWarum gibt die Methode „test()' eines globalen Regexp unerwartete Ergebnisse zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!