Array.prototype.map()
BaselineWidely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Experimente
const array1 = [1, 4, 9, 16];// Pass a function to mapconst map1 = array1.map((x) => x * 2);console.log(map1);// Expected output: Array [2, 8, 18, 32]
Resumo
O métodomap() invoca a funçãocallback
passada por argumento para cada elemento do Array e devolve um novo Array como resultado.
Sintaxe
arr.map(callback[, thisArg])
Parâmetros
callback
Função cujo retorno produz o elemento do novo Array. Recebe três argumentos:
valorAtual
O valor do elemento original do Array de origem.
indice
O índice do elemento atual que está sendo processado no array.
array
O Array de origem.
thisArg
Opcional. Valor a ser utilizado como o
this
no momento da execução da funçãocallback
.
Descrição
O métodomap
chama a funçãocallback
recebida por parâmetro para cada elemento do Array original, em ordem, e constrói um novo array com base nos retornos de cada chamada. A funçãocallback
é chamada apenas para os elementos do array original que tiverem valores atribuídos; os elementos que estiverem comoundefined
, que tiverem sido removidos ou os que nunca tiveram valores atribuídos não serão considerados.
A funçãocallback
é chamada com três argumentos: o valor do elemento corrente, o índice do elemento corrente e o array original que está sendo percorrido.
Se o parametrothisArg
foi passado para o métodomap
, ele será repassado para a funçãocallback
no momento da invocação para ser utilizado como othis
. Caso contrário, o valorundefined
será repassado para uso como othis
. O valor dothis
a ser repassado para ocallback
deve respeitar asregras para determinar como o this é acessado por uma função (em inglês).
O métodomap
não modifica o array original. No entanto, a funçãocallback
invocada por ele pode fazê-lo.
A lista de elementos que serão processados pelomap
é montada antes da primeira invocação à funçãocallback
. Se um elemento for acrescentado ao array original após a chamada aomap
, ele não será visível para ocallback
. Se os elementos existentes forem modificados, os valores que serão repassados serão os do momento em que o métodomap
invocar ocallback
. Elementos removidos não serão visitados.
Exemplos
Exemplo: Mapeando um array de números para um array de raízes quadradas
O código a seguir mapeia um array de números e cria um novo array contendo o valor da raiz quadrada de cada número do primeiro array.
var numbers = [1, 4, 9];var roots = numbers.map(Math.sqrt);// roots é [1, 2, 3], numbers ainda é [1, 4, 9]
Exemplo: Mapeando um array de números usando uma funçãocallback
que contém um argumento
O código a seguir mostrar como o métodomap
funciona quando a funçãocallback
possui apenas um argumento. Esse argumento será automaticamente atribuído para cada elemento do array conforme omap
itera sobre o array original.
var numbers = [1, 4, 9];var doubles = numbers.map(function (num) { return num * 2;});// doubles é agora [2, 8, 18]. numbers ainda é [1, 4, 9]
Exemplo: usandomap
genericamente
Esse exemplo demonstra como usar o map em umString
para recuperar a representação em ASCII de cada caracter em um array de bytes:
var map = Array.prototype.map;var a = map.call("Hello World", function (x) { return x.charCodeAt(0);});// a agora vale [72, 101, 108, 108, 111, 32, 87, 111, 114, 108, 100]
Exemplo: usandomap
genericamente comquerySelectorAll
Esse exemplo demonstra como iterar sobre uma coleção de objetos recuperada através de querySelectorAll. Nesse caso, vamos pegar todos os options selecionados na tela e imprimir no console:
var elems = document.querySelectorAll("select option:checked");var values = [].map.call(elems, function (obj) { return obj.value;});
Exemplo: Usandomap
para inverter uma string
var str = "12345";[].map .call(str, function (x) { return x; }) .reverse() .join("");// Output: '54321'// Bonus: utilize '===' para verificar se a string original e a nova string são palíndromos
Exemplo: Caso de uso mais complexo
(inspirado nesse post) (em inglês)
É uma prática comum utilizar o callback com apenas um argumento (o elemento atual do array original). Algumas funções também são comumente utilizadas com um argumento, mesmo tendo argumentos adicionais opcionais. Esses hábitos podem resultar em comportamentos indesejado:
// Considere:["1", "2", "3"].map(parseInt);// Enquanto era de se esperar [1, 2, 3]// O resultado atual é [1, NaN, NaN]// parseInt é normalmente usado com apenas um argumento, mas ele possui dois.// O primeiro é uma expressão, e o segundo o radical.// Para a função callback, o Array.prototype.map repassa 3 argumentos:// o elemento corrente, o indice e o array original// O terceiro argumento é ignorado pelo parseInt, mas o segundo não, o que certamente gerou o comportamento inesperado. Veja o post para maiores detalhesfunction returnInt(element) { return parseInt(element, 10);}["1", "2", "3"].map(returnInt); // [1, 2, 3]// O resultado atual é um array de números (como esperado)// Bonus: Um jeito mais simples de conseguir o mesmo resultado sem nenhuma "pegadinha do Malandro":["1", "2", "3"].map(Number); // [1, 2, 3]
Polyfill
(veja definição emPolyfill)
O métodomap
foi introduzido ao padrão ECMA-262 na sua 5ª edição, o que significa que ele pode não estar presente em todas as implementações desse padrão. Você pode contornar esse problema inserindo o código a seguir no início dos seus scripts, permitindo o uso domap
mesmo que ele não esteja sendo suportado nativamente. Esse algoritmo é exatamente o especificado no ECMA-262 5ª edição, assumindo queObject
,TypeError
, eArray
tenham seus valores originais, e quecallback.call
avalie para o valor original de
.Function.prototype.call
// Production steps of ECMA-262, Edition 5, 15.4.4.19// Reference: http://es5.github.io/#x15.4.4.19if (!Array.prototype.map) { Array.prototype.map = function (callback, thisArg) { var T, A, k; if (this == null) { throw new TypeError(" this is null or not defined"); } // 1. Let O be the result of calling ToObject passing the |this| // value as the argument. var O = Object(this); // 2. Let lenValue be the result of calling the Get internal // method of O with the argument "length". // 3. Let len be ToUint32(lenValue). var len = O.length >>> 0; // 4. If IsCallable(callback) is false, throw a TypeError exception. // See: http://es5.github.com/#x9.11 if (typeof callback !== "function") { throw new TypeError(callback + " is not a function"); } // 5. If thisArg was supplied, let T be thisArg; else let T be undefined. if (arguments.length > 1) { T = thisArg; } // 6. Let A be a new array created as if by the expression new Array(len) // where Array is the standard built-in constructor with that name and // len is the value of len. A = new Array(len); // 7. Let k be 0 k = 0; // 8. Repeat, while k < len while (k < len) { var kValue, mappedValue; // a. Let Pk be ToString(k). // This is implicit for LHS operands of the in operator // b. Let kPresent be the result of calling the HasProperty internal // method of O with argument Pk. // This step can be combined with c // c. If kPresent is true, then if (k in O) { // i. Let kValue be the result of calling the Get internal // method of O with argument Pk. kValue = O[k]; // ii. Let mappedValue be the result of calling the Call internal // method of callback with T as the this value and argument // list containing kValue, k, and O. mappedValue = callback.call(T, kValue, k, O); // iii. Call the DefineOwnProperty internal method of A with arguments // Pk, Property Descriptor // { Value: mappedValue, // Writable: true, // Enumerable: true, // Configurable: true }, // and false. // In browsers that support Object.defineProperty, use the following: // Object.defineProperty(A, k, { // value: mappedValue, // writable: true, // enumerable: true, // configurable: true // }); // For best browser support, use the following: A[k] = mappedValue; } // d. Increase k by 1. k++; } // 9. return A return A; };}
Especificações
Specification |
---|
ECMAScript® 2026 Language Specification # sec-array.prototype.map |