首先安裝 模塊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('正常執行的方法');
沒有使用異步之前,我們調用三個方法期望的結果是:輸出:方法1,方法2,方法3,但是node本身異步的機制決定了它不能像其他同步語言一樣正常輸出,結果輸出是以時間花費最少的先執行:結果
這就是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("方法執行完畢"+result); } } );} seriesFunc();
運行結果是否是我們期望的一次執行呢?
結果果然是我們期待的一樣,順序進行執行,node異步的機制就決定了,響應速度快,做web開發的優勢。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。
新聞熱點
疑難解答