nodejs使用async模塊同步執(zhí)行的方法
首先安裝 模塊async
測試代碼:
call.js
exports.fun1 = function (callback) { setTimeout(function(){ console.log('方法1'); callback('1'); },1900); } exports.fun2 = function (callback) { setTimeout(function(){ console.log('方法2'); callback('2'); },1700); } exports.fun3 = function (callback) { setTimeout(function(){ console.log('方法3'); callback('3'); },1500); }
test.js:
var async = require('async'); var step = require('step'); var call = require('./call'); call.fun1(function(data){ console.log(data); }); call.fun2(function(data){ console.log(data); }); call.fun3(function(data){ console.log(data); }); console.log('正常執(zhí)行的方法');
沒有使用異步之前,我們調用三個方法期望的結果是:輸出:方法1,方法2,方法3,但是node本身異步的機制決定了它不能像其他同步語言一樣正常輸出,結果輸出是以時間花費最少的先執(zhí)行:結果
這就是node的異步機制,我們使用async同步模塊進行再次測試
加入代碼:
function seriesFunc() { async.series([ function(callback) { call.fun1(function(data){ callback(null,data); }); }, function(callback) { call.fun2(function(data){ callback(null,data); }); }, function(callback) { call.fun3(function(data){ callback(null,data); }); }], function(error,result) { if(error) { console.log("error: ",error,"msg: ",result); } else { console.log("方法執(zhí)行完畢"+result); } } ); } seriesFunc();
運行結果是否是我們期望的一次執(zhí)行呢?
結果果然是我們期待的一樣,順序進行執(zhí)行,node異步的機制就決定了,響應速度快,做web開發(fā)的優(yōu)勢。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
相關文章
詳解node+express+ejs+bootstrap構建項目
本篇文章主要介紹了詳解node+express+ejs+bootstrap構建項目,非常具有實用價值,需要的朋友可以參考下2017-09-09node如何將package.json中的包降為低版本或者升級為高版本
比如現在你用某個包的當前版本,但是你安裝的版本高了,那么你應該這么做,首先刪除node項目中的node_modules目錄,防止安裝時的包不一致,下面給大家介紹node將package.json中的包降為低版本或者升級為高版本的方法,感興趣的朋友一起看看吧2023-11-11