async和await是 ES7 引入的標準之一。建立在 promise 的語法基礎上,只要 function 標記為 async,就表示裡頭可以撰寫 await 的同步語法,而 await 顧名思義就是「等待」,它會確保一個 promise 物件都解決 ( resolve ) 或出錯 ( reject ) 後才會進行下一步。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
  <h2>JavaScript async / await 範例</h2>
  <p>請再等待3秒....</p>  
  <h1 id="demo"></h1>  
  <script>
  async function myDisplay() {
    let myPromise = new Promise(function(myResolve, myReject) {
      setTimeout(function() { myResolve("Hello async / await !!"); }, 3000);
    });
    document.getElementById("demo").innerHTML = await myPromise;
  }  
  myDisplay();
  </script>  
   
</body>
</html>