Baseline Widely available
Ein Rückverweis bezieht sich auf den Teilstring einer vorherigen erfassenden Gruppe und stimmt mit demselben Text wie diese Gruppe überein. Für benannte erfassende Gruppen bevorzugen Sie möglicherweise die Syntax für benannte Rückverweise.
SyntaxHinweis: N
ist kein literales Zeichen.
N
Eine positive ganze Zahl, die sich auf die Nummer einer erfassenden Gruppe bezieht.
Ein Rückverweis ist eine Möglichkeit, denselben Text zu matchen, der zuvor von einer erfassenden Gruppe gematcht wurde. Die Zählung der erfassenden Gruppen beginnt bei 1, sodass das Ergebnis der ersten erfassenden Gruppe mit \1
referenziert werden kann, das der zweiten mit \2
usw. \0
ist ein Zeichenescape für das NUL-Zeichen.
Bei case-unsensitiven Vergleichen kann der Rückverweis Text mit unterschiedlicher GroÃ- und Kleinschreibung im Vergleich zum Originaltext matchen.
/(b)\1/i.test("bB"); // true
Der Rückverweis muss sich auf eine existierende erfassende Gruppe beziehen. Wenn die angegebene Zahl gröÃer ist als die Gesamtzahl der erfassenden Gruppen, wird ein Syntaxfehler ausgelöst.
/(a)\2/u; // SyntaxError: Invalid regular expression: Invalid escape
Im unicode-unaware mode werden ungültige Rückverweise zu einer veralteten oktalen Escape-Sequenz. Dies ist eine veraltete Syntax für Web-Kompatibilität, auf die Sie sich nicht verlassen sollten.
/(a)\2/.test("a\x02"); // true
Wenn die referenzierte erfassende Gruppe nicht gematcht wird (zum Beispiel, weil sie zu einer nicht gematchten Alternative in einer Disjunktion gehört) oder die Gruppe noch nicht gematcht wurde (zum Beispiel, weil sie rechts vom Rückverweis liegt), gelingt der Rückverweis immer (als ob er die leere Zeichenkette matcht).
/(?:a|(b))\1c/.test("ac"); // true
/\1(a)/.test("a"); // true
Beispiele Zitatpaarung
Die folgende Funktion matched die Muster title='xxx'
und title="xxx"
in einem String. Um sicherzustellen, dass die Anführungszeichen übereinstimmen, verwenden wir einen Rückverweis, um auf das erste Anführungszeichen zu verweisen. Der Zugriff auf die zweite erfassende Gruppe ([2]
) gibt die Zeichenkette zwischen den übereinstimmenden Anführungszeichen zurück:
function parseTitle(metastring) {
return metastring.match(/title=(["'])(.*?)\1/)[2];
}
parseTitle('title="foo"'); // 'foo'
parseTitle("title='foo' lang='en'"); // 'foo'
parseTitle('title="Named capturing groups\' advantages"'); // "Named capturing groups' advantages"
Doppelte Wörter matchen
Die folgende Funktion findet doppelte Wörter in einem String (die normalerweise Tippfehler sind). Beachten Sie, dass es die \w
Zeichenklassenescape verwendet, die nur englische Buchstaben, aber keine akzentuierten Buchstaben oder andere Alphabete matched. Wenn Sie ein generischeres Matching wünschen, sollten Sie den String möglicherweise mit Leerzeichen aufteilen und über das resultierende Array iterieren.
function findDuplicates(text) {
return text.match(/\b(\w+)\s+\1\b/i)?.[1];
}
findDuplicates("foo foo bar"); // 'foo'
findDuplicates("foo bar foo"); // undefined
findDuplicates("Hello hello"); // 'Hello'
findDuplicates("Hello hellos"); // undefined
Spezifikationen Browser-Kompatibilität Siehe auch
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4