JS多个异步请求 按顺序执行next实现解析

网络编程 2021-07-04 15:01www.168986.cn编程入门
这篇文章主要介绍了js多个异步请求 按顺序执行next实现解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

在js里面,偶尔会遇见需要多个异步按照顺序执行请求,又不想多层嵌套,,这里和promise.all的区别在于,promise或者Jquery里面的$.when 是发送多个请求,一起返回,发出去的顺序是一起;这里是按照顺序发请求

创建一个迭代器,接收任意多个函数参数

function nextRegister(){
      var args = arguments;
      var count = 0;
      var m = {};
      function nextTime(){
        count++;
        if(count < args.length){
          if(args[count] && Object.prototype.toString.call(args[count]) == '[object Function]'){
            args[count](m,nextTime);
          }
        }
      }
      if(args[count] && Object.prototype.toString.call(args[count]) == '[object Function]'){
        args[count](m,nextTime);
      } 
    } 

创建多个异步的函数,注入到迭代器中

/
     m:多个函数,公用的变量
     next:调用下一个函数
      /
    function fn1(m,next){
      console.log('1');
      m.age = 20;
      next();
    }
    function fn2(m,next){
      next();
      console.log('2');
      console.log(m.age);
    }
    function fn3(m,next){
      console.log('3');
    }
//开始执行迭代
nextRegister(fn1,fn2,fn3);

在这里,fn1-fn3函数中,做异步操作,知道在异步成功的时候调用next()就可以继续执行下一个函数,可以将前面函数返回的结果,绑定在m上,带到下一个函数中

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by