nodejs實現(xiàn)函數(shù)串行執(zhí)行
成都創(chuàng)新互聯(lián)公司主要從事成都網(wǎng)站建設、網(wǎng)站建設、網(wǎng)頁設計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務。立足成都服務興和,10多年網(wǎng)站建設經(jīng)驗,價格優(yōu)惠、服務專業(yè),歡迎來電咨詢建站服務:028-86922220
眾所周知,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ù)的回調(diào)函數(shù)里面就好了呀,但是有過開發(fā)經(jīng)驗的朋友一定知道,要是情況比較復雜時就會產(chǎn)生一個回調(diào)地獄的問題,即層層嵌套,最后都不知道自己寫了些什么,可讀性和維護性很差。
我們不防換個思路,要是將這些想要順序執(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ā)中大家可以定義一個模塊,將這個串行打包,再也不用害怕回調(diào)地獄問題啦。
還可以用第三方庫,如async.
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對創(chuàng)新互聯(lián)的支持。如果你想了解更多相關內(nèi)容請查看下面相關鏈接
新聞名稱:Nodejs中怎么實現(xiàn)函數(shù)的串行執(zhí)行
文章起源:http://aaarwkj.com/article32/gdshsc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、關鍵詞優(yōu)化、微信小程序、小程序開發(fā)、響應式網(wǎng)站、營銷型網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)