Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.

View in English Always switch to English

RegExp.prototype.compile()

Veraltet: Diese Funktion wird nicht mehr empfohlen. Obwohl einige Browser sie möglicherweise noch unterstützen, könnte sie bereits aus den relevanten Webstandards entfernt worden sein, in Kürze entfernt werden oder nur noch aus Kompatibilitätsgründen bestehen. Vermeiden Sie die Verwendung und aktualisieren Sie vorhandenen Code, falls möglich; siehe die Kompatibilitätstabelle am Ende dieser Seite, um Ihre Entscheidung zu unterstützen. Beachten Sie, dass diese Funktion jederzeit aufhören könnte zu funktionieren.

Hinweis: Die Methode compile() ist nur aus Kompatibilitätsgründen spezifiziert. Die Verwendung von compile() führt dazu, dass die ansonsten unveränderlichen Regex-Quelle und -Flags veränderlich werden, was die Erwartungen der Benutzer möglicherweise bricht. Sie können stattdessen den RegExp()-Konstruktor verwenden, um ein neues reguläres Ausdrucksobjekt zu erstellen.

Die compile()-Methode von RegExp-Instanzen wird verwendet, um einen regulären Ausdruck mit einer neuen Quelle und neuen Flags neu zu kompilieren, nachdem das RegExp-Objekt bereits erstellt wurde.

Syntax

js
compile(pattern, flags)

Parameter

pattern

Der Text des regulären Ausdrucks.

flags

Jede Kombination von Flag-Werten.

Rückgabewert

Keiner (undefined).

Ausnahmen

TypeError

Wird ausgelöst, wenn der this-Wert keine Instanz des RegExp-Konstruktors des aktuellen Realm ist. Dies schließt eine Unterklasse von RegExp und den RegExp-Konstruktor aus einem anderen Realm ein.

Beispiele

Verwendung von compile()

Das folgende Beispiel zeigt, wie man einen regulären Ausdruck mit einem neuen Muster und einem neuen Flag neu kompiliert.

js
const regexObj = /foo/gi;
regexObj.compile("new foo", "g");

Spezifikationen

Specification
ECMAScript® 2026 Language Specification
# sec-regexp.prototype.compile

Browser-Kompatibilität

Siehe auch