您好,登錄后才能下訂單哦!
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()
換個順序:
addTask(task1); addTask(task3); addTask(task2); next();
ok,大功告成?;谶@個思想,在實際開發(fā)中大家可以定義一個模塊,將這個串行打包,再也不用害怕回調地獄問題啦。
還可以用第三方庫,如async.
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內(nèi)容請查看下面相關鏈接
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。