HTML: Markup language
CSS: Styling language
JavaScript: Scripting language
Web APIs: Programming interfaces
All web technology
Learn web development
Discover our tools
Get to know MDN better
Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.
View in English Always switch to English
Diese Funktion ist gut etabliert und funktioniert auf vielen Geräten und in vielen Browserversionen. Sie ist seit Juli 2015 browserübergreifend verfügbar.
Die test()-Methode von RegExp-Instanzen führt eine Suche mit diesem regulären Ausdruck durch, um nach einer Übereinstimmung zwischen einem regulären Ausdruck und einem angegebenen String zu suchen. Sie gibt true zurück, wenn eine Übereinstimmung gefunden wird, andernfalls false.
test()
RegExp
true
false
JavaScript-RegExp-Objekte sind zustandsbehaftet, wenn sie die Flags global oder sticky gesetzt haben (z.B. /foo/g oder /foo/y). Sie speichern einen lastIndex aus dem vorherigen Treffer. Intern verwendet kann test() verwendet werden, um über mehrere Übereinstimmungen in einem Textstring zu iterieren (mit Erfassungsgruppen).
global
sticky
/foo/g
/foo/y
lastIndex
const str = "table football"; const regex = /fo+/; const globalRegex = /fo+/g; console.log(regex.test(str)); // Expected output: true console.log(globalRegex.lastIndex); // Expected output: 0 console.log(globalRegex.test(str)); // Expected output: true console.log(globalRegex.lastIndex); // Expected output: 9 console.log(globalRegex.test(str)); // Expected output: false
test(str)
str
Der String, gegen den der reguläre Ausdruck abgeglichen werden soll. Alle Werte werden in Strings umgewandelt, daher führt das Weglassen oder Übergeben von undefined dazu, dass test() nach dem String "undefined" sucht, was selten gewünscht ist.
undefined
"undefined"
true, wenn eine Übereinstimmung zwischen dem regulären Ausdruck und dem String str besteht. Andernfalls false.
Verwenden Sie test(), wann immer Sie wissen möchten, ob ein Muster in einem String gefunden wird. test() gibt einen booleschen Wert zurück, anders als die String.prototype.search()-Methode (die den Index einer Übereinstimmung oder -1 zurückgibt, wenn keine gefunden wird).
String.prototype.search()
-1
Um mehr Informationen zu erhalten (aber mit langsamerer Ausführung), verwenden Sie die exec()-Methode. (Dies ist ähnlich wie die String.prototype.match()-Methode.)
exec()
String.prototype.match()
Wie bei exec() (oder in Kombination damit) wird test(), mehrmals auf derselben globalen regulären Ausdrucksinstanz aufgerufen, über den vorherigen Treffer hinausgehen.
Dieses Beispiel überprüft, ob "hello" ganz am Anfang eines Strings enthalten ist und gibt einen booleschen Wert zurück.
"hello"
const str = "hello world!"; const result = /^hello/.test(str); console.log(result); // true
Das folgende Beispiel protokolliert eine Nachricht, die von der erfolgreichen Durchführung des Tests abhängt:
function testInput(re, str) { const midString = re.test(str) ? "contains" : "does not contain"; console.log(`${str} ${midString} ${re.source}`); }
Wenn ein Regex das global-Flag gesetzt hat, wird test() den lastIndex des Regex vorwärts verschieben. (RegExp.prototype.exec() verschiebt die lastIndex-Eigenschaft ebenfalls.)
RegExp.prototype.exec()
Weitere Aufrufe von test(str) werden die Suche in str ab lastIndex fortsetzen. Die lastIndex-Eigenschaft wird jedes Mal erhöht, wenn test() true zurückgibt.
Hinweis: Solange test() true zurückgibt, wird lastIndex nicht zurückgesetzt—even bei einem Test mit einem anderen String!
Wenn test() false zurückgibt, wird die lastIndex-Eigenschaft des aufrufenden Regex auf 0 zurückgesetzt.
0
Das folgende Beispiel demonstriert dieses Verhalten:
const regex = /foo/g; // the "global" flag is set // regex.lastIndex is at 0 regex.test("foo"); // true // regex.lastIndex is now at 3 regex.test("foo"); // false // regex.lastIndex is at 0 regex.test("barfoo"); // true // regex.lastIndex is at 6 regex.test("foobar"); // false // regex.lastIndex is at 0 regex.test("foobarfoo"); // true // regex.lastIndex is at 3 regex.test("foobarfoo"); // true // regex.lastIndex is at 9 regex.test("foobarfoo"); // false // regex.lastIndex is at 0 // (...and so on)
JavaScript aktivieren, um diese Browser-Kompatibilitätstabelle anzuzeigen.