91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

javascript中sleep的使用方法

發布時間:2020-06-19 11:20:28 來源:億速云 閱讀:190 作者:Leah 欄目:web開發

這期內容當中小編將會給大家帶來有關javascript中sleep的使用方法,以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

很多編程語言里都有sleep()delay()等方法,它能讓我們的程序不那么著急的去執行下一步操作,而是延遲、等待一段時間。軟件開發中經常會遇到需要這樣的函數,比如等待幾分鐘去檢查某一事件是否發生。JavaScript里有setTimeout()方法來實現設定一段時間后執行某個任務,但寫法很丑陋,需要提供回調函數:

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

JavaScript Promise API是新出現了一個API,借助 Promise,我們可以對setTimeout函數進行改良,下面就是把setTimeout()封裝成一個返回Promise的sleep()函數。

// 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)函數。

這里需要提到的一個問題是,這個sleep()在執行的時候是“block”程序的繼續執行的。它不是同步的。如果想讓它同步執行,不妨礙執行之后的代碼,我們可以使用 async/await 關鍵字。

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

執行結果:

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的執行。

async/await 是ES7中的語法,目前還是處于試驗階段。那現在想用這個 async/await 特性怎么辦?可以嘗試 google 的一個 JavaScript 預編譯器 traceur,可以將高版本的 JavaScript 編譯為 ES5 代碼,已經實驗性的支持了 async/await (需要使用 –experimental 來指定開啟)。

上文描述的就是javascript中sleep的使用方法,具體使用情況還需要大家自己動手實驗使用過才能領會。如果想了解更多相關內容,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

富宁县| 微山县| 嘉黎县| 曲沃县| 无极县| 宁强县| 东莞市| 太康县| 阳曲县| 宜都市| 临潭县| 来安县| 彭阳县| 达拉特旗| 马山县| 邢台县| 汪清县| 芦山县| 敦煌市| 白银市| 台州市| 开封市| 新邵县| 安乡县| 南通市| 武城县| 泰宁县| 土默特左旗| 社会| 南木林县| 名山县| 文登市| 左云县| 娄底市| 兰坪| 醴陵市| 彰化县| 奎屯市| 集安市| 宝鸡市| 冀州市|