關于JavaScript,我們經常會聽到“異步函數”的說法,那么究竟什么樣的函數是異步的呢?在這篇文章中,我將從常見的幾個方向上,為大家詳細舉例解讀。
異步函數主要都是與網絡請求和定時器相關的函數。例如,XMLHttpRequest對象(簡稱XHR)的open和send方法,setTimeout、setInterval函數以及Promise的resolve和reject方法,都是異步函數的代表。
首先來看XHR對象,它是用于在瀏覽器中發送HTTP請求和接收HTTP響應的對象。我們使用時需要先創建實例,然后通過該實例來進行后續操作。其中,open方法用于設置請求的方法、URL以及是否使用異步,默認情況下,所有的XHR請求都是異步的;send方法用于發送請求并接收響應。接下來是相關代碼的示例:
var xhr = new XMLHttpRequest(); xhr.open('GET', 'some_url', true); //true代表異步 xhr.onreadystatechange = function () { if (xhr.readyState === 4 && xhr.status === 200) { console.log(xhr.responseText); //響應結果 } }; xhr.send(null);這里使用了XHR的onreadystatechange事件來獲取響應結果,當readyState改變時就會被觸發。需要注意的是,XHR請求是異步的,也就是說,在調用xhr.send方法后,請求還沒有結束,我們在此之后的代碼依然可以被執行。 接下來是setTimeout和setInterval函數。它們都是用于定時執行某段代碼的函數,但是二者有一個很大的區別:setTimeout只會執行一次,而setInterval則可以無限循環執行。示例代碼如下:
setTimeout(function () { console.log('我只會被執行一次'); }, 1000); setInterval(function () { console.log('我會不停地被執行'); }, 1000);需要注意的是,setTimeout和setInterval都是異步函數,因為它們在經過了一定時間后才會執行,我們并不能保證它們會在預定時間內一定被執行,而不會受到其他因素的影響。 最后再來看一下Promise對象。Promise是一種比較新的異步編程解決方案,可以有效地避免“回調地獄”的出現。簡單地說,Promise有三種狀態:未完成、已完成、已失敗。resolve和reject方法分別用于將狀態改為已完成和已失敗。接下來是例子:
var promise = new Promise(function (resolve, reject) { setTimeout(resolve, 1000); }); promise.then(function () { console.log('Promise狀態已變為已完成!'); }); promise.catch(function () { console.log('Promise狀態已變為已失敗!'); });在這個例子中,我們使用setTimeout將Promise的狀態改為已完成,并在then方法中獲取了狀態變化后的結果。需要注意的是,Promise是一個異步對象,我們無法保證Promise的狀態會在我們需要時刻一定被改變。 綜上所述,JavaScript 中的異步函數主要包括XHR對象的open和send方法、setTimeout和setInterval函數以及Promise的resolve和reject方法。在使用這些異步函數時,我們需要時刻注意它們不像同步函數一樣,按照從上到下的順序執行,而是存在一定的異步操作,需要通過回調函數、Promise等手段來獲取返回結果。
下一篇css中號的意思