Sintaxe
async function [nome]([parametro1[, parametro2[, ..., parametroN]]]) { declarações }
Como no ES2015, você tambem pode usar arrow functions.
Parâmetros
nome
- O nome da função.Pode ser omitida, na qual a função se torna anonima . O nome é somente local para o corpo da função.
parametroN
- O nome do argumento passado para a função.
declarações
- As declarações que compoem o corpo da função .
Descrição
Uma expressão async function
é muito similar, e tem quase a mesma sintaxe de uma declaração async function
. A principal diferença entre uma expressão async function
e uma declaração async function
é o nome da função, que pode ser omitido em expressões async function
para criar funções anônimas. Uma expressão async function
pode ser utilizada como um IIFE (Immediately Invoked Function Expression, em tradução livre: Expressão de Função Invocada Imediatamente) que roda assim que definido. Veja também o capítulo sobre funções para mais informações.
Exemplos
Exemplo simples
function resolveAfter2Seconds(x) { return new Promise(resolve => { setTimeout(() => { resolve(x); }, 2000); }); }; (async function(x) { // async function expression usada como uma IIFE var a = resolveAfter2Seconds(20); var b = resolveAfter2Seconds(30); return x + await a + await b; })(10).then(v => { console.log(v); // imprime 60 após 2 segundo. }); var add = async function(x) { // async function expression atribuída a uma variável var a = await resolveAfter2Seconds(20); var b = await resolveAfter2Seconds(30); return x + a + b; }; add(10).then(v => { console.log(v); // imprime 60 após 4 segundos. });
Especificações
Especificação | Status | Comentário |
---|---|---|
ECMAScript Latest Draft (ECMA-262) The definition of 'async function' in that specification. |
Rascunho | Definição inicial no ES2017. |
Compatibilidade de navegadores
Feature | Chrome | Firefox (Gecko) | Internet Explorer | Edge | Opera | Safari (WebKit) |
---|---|---|---|---|---|---|
Basic support | 55 | 52.0 (52.0) | ? | ? | 42 | ? |
Feature | Android | Android Webview | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile | Chrome for Android |
---|---|---|---|---|---|---|---|
Basic support | ? | ? | 52.0 (52.0) | ? | 42 | ? | 55 |
Veja também
async function
AsyncFunction
objectawait