Nodejs中怎么實現(xiàn)函數(shù)的串行執(zhí)行
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.
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
相關文章
Grunt針對靜態(tài)文件的壓縮,版本控制打包的實例講解
下面小編就為大家?guī)硪黄狦runt針對靜態(tài)文件的壓縮,版本控制打包的實例講解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09為nuxt項目寫一個面包屑cli工具實現(xiàn)自動生成頁面與面包屑配置
這篇文章主要介紹了為nuxt項目寫一個面包屑cli工具實現(xiàn)自動生成頁面與面包屑配置,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-09-09node.js中的fs.writeFileSync方法使用說明
這篇文章主要介紹了node.js中的fs.writeFileSync方法使用說明,本文介紹了fs.writeFileSync的方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下2014-12-12