首頁 > web前端 > js教程 > 主體

nodejs async非同步常用函數實例分享

小云云
發布: 2018-01-18 13:20:50
原創
1489 人瀏覽過

本文主要介紹了nodejs async非同步常用函數總結的相關資料,需要的朋友可以參考下,希望能幫助到大家。

nodejs框架類別庫很多,「流程控制」本來是件比較簡單的事,但是對於nodejs的非同步架構的實作方法,對於需要同步的業務邏輯,實作起來比較麻煩。

async的集合控制:


async.map(arr, function(item, callback){},callback(err, results){});async.mapSeries
登入後複製



app.get('/testMap',function(req, res){
 var arr = [0,1,2,3,4,5,6];
 async.mapSeries(arr,function(item, callback){
  (function(){
  callback(null, item+1);
  }());
 },function(err, results){
  console.log(results);//[1,2,3,4,5,6,7];
 });
 });
登入後複製

results .length與arr.length值相等;

對數組arr中的每個item,執行某個非同步函數function,得到結果。所有的結果將匯總到最終的callback裡;

async的流程控制:

async.series(tasks,callback);多個函數依次執行,之間沒有數據交換


app.get('/testSeries',function(req, res){
 async.series([
 function(callback){
  callback(null,'function1');
 },function(callback){
  callback(null, 'function2')
 },function(callback){
  callback(null, 'function3');
 }],function(err, results){
  console.log(results);//['function1','function2','function3'];
 });
 });
登入後複製


#
tasks: functionList;
callback: function(err, result){}
登入後複製

序列執行,一個函數陣列中的每個函數執行完成之後,才執行下一個函數,callback(err,results);err傳回錯誤訊息,results為多個函數的傳回的結果集;

如果任何一個函數向它的回呼函數中傳了一個error,則後面的函數都不會被執行,並且將會立刻會將該error以及已經執行了的函數的結果,傳給series中最後那個callback

async.parallel(tasks,callback) ;多個函數並行執行;


app.get('/testParallel',function(req, res){
 async.parallel([
 function(callback){
  callback(null,'function1');
 },function(callback){
  callback(null, 'function2')
 },function(callback){
  callback(null, 'function3');
 }],function(err, results){
  console.log(results);//['function1','function2','function3'];
 });
});
登入後複製

tasks: functionList;

callback:function(err, results) {}

tasks.length與results.length值相等

#並行執行多個函數,每個函數都是立即執行,不需要等待其它函數先執行.傳給最終callback數組中的資料按照tasks中聲明的順序,而不是執行完成的順序;

如果某個函數出錯,則立刻將err和已經執行完的函數的結果值傳給parallel最終的callback。其它未執行完的函數的值不會傳到最終數據,但要佔個位置

async.whilst(test,function,callback);可用於非同步呼叫while


app.get('/testWhilst',function(req, res){
 var count = 0;
 async.whilst(function(){
  if(count < 3) return true;
 },function(callback){
  (function(){
  count++;
  callback(null);
  }());
 },function(err){
  console.log(count);//3
 });
 });
登入後複製

相關推薦:

#JS非同步函數佇列功能實例分析

取得JavaScript非同步函數的回傳值實例詳解

詳細介紹JavaScript非同步函數發展歷程程式碼範例

#

以上是nodejs async非同步常用函數實例分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板