Node.js使用Promise解决循环异步后再执行问题


在异步方法执行后再执行的直接解决方案就是写回调。

可是如果想让所有的(例如循环调用的若干次)异步方法全部执行完之后再执行接下来的方法该怎么办呢?

本文基于Promise语法,给出解决方案。


接着上一篇的例子,我们先来看一下有问题的写法。


有问题的写法:



 
 
  1. var request = require( 'request');
  2. // 异步获取网络资源的方法
  3. getWeb = (index, getCallback) => {
  4. var url = 'http://www.duzixi.com';
  5. request(url, function (error, response, body) {
  6. if (!error && response.statusCode == 200)
  7. {
  8. getCallback(body);
  9. return body;
  10. } else {
  11. console.log(response.statusCode + " " + error);
  12. getCallback( "");
  13. return "";
  14. }
  15. })
  16. }
  17. // 循环调用
  18. for ( var i = 0; i <= 10; i++) {
  19. ( (index)=>{
  20. getWeb(index, (body)=>{
  21. console.log(index);
  22. })
  23. })(i)
  24. }
  25. console.log( "All done!");


神奇的运行结果:

All done!
1
2
3
0
4
6
5
7
9
8
10

源代码最后输出的All done! 居然出现在了最上面。

原因相比不用多说大家也知道,由于异步方法是花费时间的,所以输出事件后发生。


问题的解决方案:


这个问题的解决方案就是Promise,循环调用部分的源代码修改如下:

var actions = [];  // 定义一个空的方法数组

 
 

 
 
  1. // 循环调用
  2. for ( var i = 0; i <= 10; i++) {
  3. var action = () => { // 将每一次循环方法定义为一个方法变量
  4. return new Promise( resolve =>{ // 每个方法返回一个Promise对象,第一个参数为resolve方法
  5. ( (index)=>{
  6. getWeb(index, (body)=>{
  7. console.log(index);
  8. resolve(); // 在方法结束时调用resolve()方法
  9. })
  10. })(i)
  11. })
  12. }
  13. actions.push(action()); // 将每次循环调用的方法添加到方法数组中
  14. }
  15. Promise.all(actions).then( ()=>{ // 调用Promise的all方法,传入方法数组,结束后执行then方法参数中的方法
  16. console.log( "All done!");
  17. });

最终的运行结果:

8
7
5
9
4
1
10
6
2
3
0
All done!


最后,感谢小红帮助解答了该问题。


注:本文转自Node.js的那些坑,作者:莲兮奈若何

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值