--- title: 非同期関数式 slug: Web/JavaScript/Reference/Operators/async_function tags: - Function - JavaScript - Language feature - Operator - Primary Expression translation_of: Web/JavaScript/Reference/Operators/async_function ---
async function
キーワードは、式の中で async
関数を定義するために使用できます。
非同期関数は、 async function 文を使用して定義することもできます。
async function [name]([param1[, param2[, ..., paramN]]]) { statements }
ES2015 では、アロー関数を使用することもできます。
name
paramN
statements
async function
式は {{jsxref('Statements/async_function', 'async function statement')}} と非常に似ており、構文もほとんど同じです。async function
式と async function
文の主な違いは、async function
式が無名関数を生成するために関数名を省略できる点です。async function
式は、定義後直ちに実行される IIFE (即時実行関数式) として使用することもできます。詳細は関数の章を見てください。
function resolveAfter2Seconds(x) { return new Promise(resolve => { setTimeout(() => { resolve(x); }, 2000); }); }; const add = async function(x) { // 変数に代入された非同期関数式 let a = await resolveAfter2Seconds(20); let b = await resolveAfter2Seconds(30); return x + a + b; }; add(10).then(v => { console.log(v); // 4 秒後に 60 を表示 }); (async function(x) { // IIFE として使用される非同期関数式 let p_a = resolveAfter2Seconds(20); let p_b = resolveAfter2Seconds(30); return x + await p_a + await p_b; })(10).then(v => { console.log(v); // 2 秒後に 60 を表示 });
仕様書 |
---|
{{SpecName('ESDraft', '#sec-async-function-definitions', 'async function')}} |
{{Compat("javascript.operators.async_function")}}