Baseline Widely available
A palavra chave async pode ser usado para definir funções async dentro das expressões.Você tambem pode definir funções async usando a declaração de função async.
Sintaxeasync function [nome]([parametro1[, parametro2[, ..., parametroN]]]) { declarações }
Como no ES2015, você tambem pode usar arrow functions.
Parâmetrosnome
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 .
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.
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 Compatibilidade com navegadores Veja também
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4