當(dāng)前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
javascript --- 异步函数的顺序进行
生活随笔
收集整理的這篇文章主要介紹了
javascript --- 异步函数的顺序进行
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
假設(shè)我們希望某一組異步函數(shù)能一次進(jìn)行,在不使用的任何工具的情況下,可能會編寫出類似下面的代碼:
funcs[0](function() {funcs[1](function() {funcs[2](onComplete);}) });// 注:以上代碼運行會出現(xiàn)的一些不方便: // 1.回調(diào)太深,不利于閱讀..(100層嵌套...); // 2.不能使用循環(huán),只能一個一個手動的敲...幸好我們還有async.series和async.waterfall。這兩個方法均接受一組函數(shù)(即任務(wù)列表)作為參數(shù)并按順序運行它們.
// async.series var async = require('async'): var start = new Date;async.series([function(callback) {setTimeout(callback, 100);},function(callback) {setTimeout(callback, 200);},function(callback) {setTimeout(callback, 300);} ],function(err, results){console.log('Completed in' + (new Date - start) + 'ms'); });// 注:以上函數(shù)會在運行后600毫秒之后(大于600毫秒)結(jié)束下面再介紹一種并行運行的異步函數(shù)
// async.parallel var async = require('async'); var start = new Date; async.parallel([function(callback) { setTimeout(callback, 100); },function(callback) { setTimeout(callback, 300); },function(callback) { setTimeout(callback, 200); } ], function(err, results) {console.log('Completed in ' + (new Date - start) + 'ms'); }); // 注:約大于300毫秒后結(jié)束..參考《JavaScript異步編程》— 設(shè)計快速響應(yīng)的網(wǎng)絡(luò)應(yīng)用 P76~P77
總結(jié)
以上是生活随笔為你收集整理的javascript --- 异步函数的顺序进行的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 鸿蒙关键技术研究,华为鸿蒙 2.0 系统
- 下一篇: javascript --- 异步工作