溫馨提示×

溫馨提示×

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

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

Nodejs中怎么實現(xiàn)函數(shù)的串行執(zhí)行

發(fā)布時間:2020-09-23 17:39:39 來源:腳本之家 閱讀:324 作者:編碼的哲哲 欄目:web開發(fā)

nodejs實現(xiàn)函數(shù)串行執(zhí)行

眾所周知,nodejs是用非阻塞異步io機制,也就是說函數(shù)執(zhí)行完成的先后順序和代碼的編寫的先后順序可能不同,實際的順序取決于一個函數(shù)自身執(zhí)行的快慢。這就出現(xiàn)一個在nodejs中怎么編寫串行執(zhí)行也就是順序執(zhí)行代碼的問題。試想,要是你寫了2個函數(shù),一個查詢數(shù)據(jù)庫,另一個返回查詢的結果,要是不用串行執(zhí)行那么還沒等數(shù)據(jù)庫查詢完畢就返回了結果,這顯然是不行的。因而串行執(zhí)行在nodejs中很有用。那么怎么實現(xiàn)呢?

大家可能會說,將返回查詢結果的函數(shù)寫在查詢數(shù)據(jù)庫函數(shù)的回調函數(shù)里面就好了呀,但是有過開發(fā)經(jīng)驗的朋友一定知道,要是情況比較復雜時就會產(chǎn)生一個回調地獄的問題,即層層嵌套,最后都不知道自己寫了些什么,可讀性和維護性很差。

我們不防換個思路,要是將這些想要順序執(zhí)行的函數(shù)放到一個數(shù)組里面,當一個函數(shù)執(zhí)行完畢時在執(zhí)行數(shù)組里面的下一個函數(shù)不就行了嘛。其實,nodejs開源社區(qū)中的很多串行模塊的基本思想就是這個。接下來我們一步一步完成這個串行的demo:

1.首先我們定義一個保存函數(shù)執(zhí)行順序的數(shù)值:

var tasks = [];

2.再定義一個往數(shù)值里面加入串行化執(zhí)行函數(shù)的函數(shù):

function addTask(task){
     tasks.push(task);
}

3.執(zhí)行數(shù)組中下一個函數(shù)的函數(shù):

function next(){
     if(tasks.length > 0){
        tasks.shift()();
     }else{
       return;   
     }
}

ok,大功告成,接下來定義幾個測試函數(shù):

var task1 = function(){
     console.log('task1 is finished');
     next();
}
var task2 = function(){
     console.log('task2 is finished');
     next();}var task3 = function(){
     console.log('task3 is finished');
     next();
}

開始測試:

addTask(task1);
addTask(task2);
addTask(task3);
next()

Nodejs中怎么實現(xiàn)函數(shù)的串行執(zhí)行

換個順序:

addTask(task1);
addTask(task3);
addTask(task2);
next();

Nodejs中怎么實現(xiàn)函數(shù)的串行執(zhí)行

ok,大功告成?;谶@個思想,在實際開發(fā)中大家可以定義一個模塊,將這個串行打包,再也不用害怕回調地獄問題啦。

還可以用第三方庫,如async.

總結

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內(nèi)容請查看下面相關鏈接

向AI問一下細節(jié)

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

AI