这篇文章主要给大家介绍了关于node.js多个异步过程中判断执行是否完成的几种解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
前言
本文主要给大家介绍了关于node.js多个异步过程中判断执行是否完成的相关内容,可能这样说大家不是很明白,下面来一起看看详细的介绍吧。
场景:
想请求量较大的网络数据,比如想获取1000条结果,但数据处理速度慢,有超时的风险,可以分成10次处理,每次处理100条;所有请求完成后再统一进行处理。
这样的应用场景,可以这样处理:
方案一:判断请求到的数据条目
// 模拟网络请求function fetch(url, callback) { settimeout(function (){ callback(null, { subjects: [{ data: math.round(math.random() * 100) }] }); }, 2000);}// 实现方案1function multitask_1 () { var arr = []; var baseurl = 'https://api.douban.com/v2/movie/top250'; for (var start = 0; start < 10; start++) { var url = baseurl + '?start=' + start + "&count=1"; fetch(url, function(error, res) { var data = res.subjects; arr = arr.concat(data); // 调用完成后统一处理 if (arr.length === 10) { console.log(arr); } }); }}
将运行结果用arr.length来判断,如果arr.length不像我们期望的那样,比如由于网络传输或者处理异常,少一条,那么我们将无法做后续的处理。这种处理方式强业务耦合;不具有普适性。
方案二:判断异步过程执行次数
// 方案2function multitask_2 () { var taskwatcher = 0; var arr = []; var baseurl = 'https://api.douban.com/v2/movie/top250'; for (var start = 0; start < 10; start++) { taskwatcher++; var url = baseurl + '?start=' + start + "&count=1"; fetch(url, function(error, res) { var data = res.subjects; arr = arr.concat(data); taskwatcher--; if (taskwatcher === 0) { console.log(arr); } }); }}
方案2 的判断条件,这里的 taskwatcher 充当异步任务执行情况的观察员,仅与异步过程的调用次数有关,且与其他处理过程无关。那有没有其他方案呢
方案三:promise.all()
promise.all(iterable) 方法返回一个 promise, 它将在上述可迭代对象中的所有 promise 被 resolve 之后被 resolve,或者在任一 promise 被 reject 后被 reject。
function multitask_3 () { // var taskwatcher = 0; var taskstack = []; var arr = []; var baseurl = 'https://api.douban.com/v2/movie/top250'; for (var start = 0; start < 10; start++) { taskstack.push( new promise((resolve, reject) => { var url = baseurl + '?start=' + start + "&count=1"; fetch(url, function(error, res) { var data = res.subjects; arr = arr.concat(data); resolve(); }); }) ); } promise.all(taskstack).then(function () { console.log(arr); });}
这种方式更具有通用性,如果异步任务类型不同,也可以用这种方式来解决。不过应当注意reject的处理。避免其对最终处理的影响。
方案四: eventproxy
eventproxy是朴灵写的,https://github.com/jacksontian/eventproxy
var ep = new eventproxy(); var arr = []; ep.after('fetchdata', 10, function (list) { list.foreach(function(item){ arr = arr.concat(item); }); console.log(arr); }); var baseurl = 'https://api.douban.com/v2/movie/top250'; for (var start = 0; start < 10; start++) { var url = baseurl + '?start=' + start + "&count=1"; fetch(url, function(error, res) { var data = res.subjects; ep.emit('fetchdata', data); }); }
eventproxy基于事件订阅/发布模式,这里的after 方法可以侦听多次事件,回调中保存了多次异步任务的数据结果的数组;除此之外eventproxy还支持多个不同事件的侦听和处理。
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
使用vue-cli如何配置接口代理
在nodejs中如何使用form-data格式传输文件
在微信小程序中如何实现图片懒加载
使用js如何实现焦点图效果
以上就是在node.js中多个异步过程中如何判断执行是否完成(详细教程)的详细内容。