String.prototype.match()
Baseline
Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since julho de 2015.
Resumo
O método match() retorna uma correspondência entre uma string com uma expressão regular.
Sintaxe
str.match(regexp);
Parâmetros
regexp-
Um objeto de expressão regular. Se
regexpnão for umaRegExp, o mesmo será convertido para uma nova RegExp usandonew RegExp(regexp).Se você não fornecer nenhum parâmetro ao usar o método
match(), você obterá umArraycom uma string vazia:[""].
Valor retornado
- Se o sinalizador
gfor usado, todos os resultados correspondentes à expressão regular serão retornados, mas a captura de grupos não. - se o sinalizador
gnão for usado, apenas a primeira correspondência completa e seus grupos de captura relacionados serão retornados. Nesse caso, o item devolvido terá propriedades adicionais conforme descrito a seguir.
array-
Um
Arraycujo conteúdo depende da presença ou ausência do sinalizador global (g), ounullse nenhuma correspondência for encontrada.
Propriedades adicionais
Conforme explicado acima, alguns resultados contêm propriedades adicionais conforme descrito abaixo.
groups-
Um objeto de grupos de captura nomeados cujas chaves são os nomes, e valores são os grupos de captura ou
undefinedse nenhum grupo de captura nomeado foi definido. Consulte Grupos e Intervalos para obter mais informações. index-
O índice da pesquisa em que o resultado foi encontrado.
input-
Uma cópia da string pesquisada.
Descrição
Se a expressão regular não incluir o sinalizador g, str.match() retornará o mesmo resultado que RegExp.exec().
Veja também: métodos RegExp
- Se você precisar saber se uma string corresponde a uma expressão regular, use
RegExp.test(). - Se você quiser encontrar apenas uma correspondência, você pode querer usar
RegExp.exec(). - Se você deseja obter grupos de captura e o sinalizador global (
g) está definido, você precisa usarRegExp.exec()ouString. prototype.matchAll()em vez disso.
Exemplos
>Usando match()
No exemplo a seguir, match() é usado para encontrar "Capítulo", seguido de um ou mais caracteres numéricos, seguido por um ponto decimal e caracteres numéricos 0 ou mais vezes. A expressão inclui a flag i para que diferenças de maiúscula/minúscula sejam ignoradas.
const str = "Para maiores informações, veja o Capítulo 3.4.5.1";
const re = /(capítulo \d+(\.\d)*)/i;
const found = str.match(re);
console.log(found);
// retorna ["Capítulo 3.4.5.1",
"Capítulo 3.4.5.1",
".1",
index: 33,
input: "Para maiores informações, veja o Capítulo 3.4.5.1"]
// "Capítulo 3.4.5.1" é a primeira correspondência e o primeiro valor
// capturado a partir de (capítulo \d+(\.\d)*).
// ".1" é o útlimo valor de (\.\d).
// A propriedade "index" (33) é o índice de base zero da correspôndencia inteira.
// A propriedade "input" é a string original que foi analisada.
Usando as bandeiras (flags) global e ignore com
match()
O exemplo a seguir demonstra o uso das bandeiras (flags) global e ignore com match(). Todas as letras de A a E e a a e são retornadas, com cada letra sendo um elemento no array.
const str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
const regexp = /[A-E]/gi;
const matches_array = str.match(regexp);
console.log(matches_array);
// ['A', 'B', 'C', 'D', 'E', 'a', 'b', 'c', 'd', 'e']
Nota:
Veja também String.prototype.matchAll() e Pesquisa avançada com sinalizadores.
Usando grupos de captura nomeados
Em navegadores que suportam grupos de captura nomeados, o código a seguir captura "fox" ou "cat" em um grupo denominado "animal":
const paragraph = "The quick brown fox jumps over the lazy dog. It barked.";
const capturingRegex = /(?<animal>fox|cat) jumps over/;
const found = paragraph.match(capturingRegex);
console.log(found.groups); // {animal: "fox"}
Usando match() sem parâmetros
const str = "nada se perde, tudo se transforma";
str.match(); // retorna [""]
Um objeto não-RegExp como parâmetro
Quando o parâmetro regexp é uma string ou um número, ele é convertido implicitamente em um RegExp usando o new RegExp(regexp).
Se for um número positivo com um sinal positivo, RegExp() irá ignorar o sinal positivo.
const str1 =
"NaN significa 'não é um número'. Infinity contem -Infinity e +Infinity em JavaScript.";
const str2 = "Meu avô tem 65 anos e minha avô tem 63.";
const str3 = "O contrato foi declarado null (nulo) e void (sem efeito)";
str1.match("número"); // "número" é um string. retorna ["número"]
str1.match(NaN); // o tipo de NaN é um número. retorna ["NaN"]
str1.match(Infinity); // o tipo de Infinity é um número. retorna ["Infinity"]
str1.match(+Infinity); // retorna ["Infinity"]
str1.match(-Infinity); // retorna ["-Infinity"]
str2.match(65); // retorna ["65"]
str2.match(+65); // Um número com sinal positivo. retorna ["65"]
str3.match(null); // retorna ["null"]
Especificações
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-string.prototype.match> |
Navegadores compatíveis
Loading…