javascript裏的sleep()方法

不少編程語言裏都有sleep()delay()等方法,它能讓咱們的程序不那麼着急的去執行下一步操做,而是延遲、等待一段時間。軟件開發中常常會遇到須要這樣的函數,好比等待幾分鐘去檢查某一事件是否發生。JavaScript裏有setTimeout()方法來實現設定一段時間後執行某個任務,但寫法很醜陋,須要提供回調函數:javascript

setTimeout(function(){ alert("Hello"); }, 3000);

JavaScript Promise API是新出現了一個API,藉助 Promise,咱們能夠對setTimeout函數進行改良,下面就是把setTimeout()封裝成一個返回Promise的sleep()函數。java

// https://zeit.co/blog/async-and-await
function sleep (time) {
  return new Promise((resolve) => setTimeout(resolve, time));
}

// 用法
sleep(500).then(() => {
    // 這裏寫sleep以後須要去作的事情
})

你會發現,這種寫法很優雅,很像其它編程語言裏的延遲、等待函數。Promise API使咱們避免傳入回調函數,咱們在實現中還使用了ES6中的箭頭(arrow)函數。web

這裏須要提到的一個問題是,這個sleep()在執行的時候是「block」程序的繼續執行的。它不是同步的。若是想讓它同步執行,不妨礙執行以後的代碼,咱們能夠使用 async/await 關鍵字。編程

(async function() {
  console.log('Do some thing, ' + new Date());
  await sleep(3000);
  console.log('Do other things, ' + new Date());
})();

執行結果:api

Do some thing, Mon Feb 23 2015 21:52:11 GMT+0800 (CST)  
Do other things, Mon Feb 23 2015 21:52:14 GMT+0800 (CST)

你會發現,這一次,sleep()並無阻礙第二個console的執行。promise

 async/await 是ES7中的語法,目前仍是處於試驗階段。那如今想用這個 async/await 特性怎麼辦?能夠嘗試 google 的一個 JavaScript 預編譯器 traceur,能夠將高版本的 JavaScript 編譯爲 ES5 代碼,已經實驗性的支持了 async/await (須要使用 –experimental 來指定開啓)。async

 

 

原文地址http://it.lindukj.cn/archives/1680編程語言

相關文章
相關標籤/搜索