zoukankan      html  css  js  c++  java
  • 基于PROMISE解决回调地狱问题

      回调地狱问题:

        在使用JavaScript时,为了实现某些逻辑经常会写出层层嵌套的回调函数,如果嵌套过多,会极大影响代码可读性和逻辑,这种情况也被成为回调地狱。比如说你要把一个函数 A 作为回调函数,但是该函数又接受一个函数 B 作为参数,甚至 B 还接受 C 作为参数使用,就这样层层嵌套,人称之为回调地狱,代码阅读性非常差。

        例如:要发送三个异步的请求要求前面一个请求完成之后再依次发送请求。

    $.ajax{
        url:'url1',
        success:result=>{
            $.ajax{
                url:'url2',
                success:result=>{
                    $.ajax{
                        url:'url3',
                        success:result=>{
                            
                        }
                    };
                }
            };
        }
    };//这就是一个栗子

        基于PROMISE解决

        Promise:ES6新增的内置类,是为了管理异步操作的。

    //封装成多个方法
    let queryA = function(){
        return new Promise(resolve=>{
            $.ajax({
                url:'url1',
                success:resolve,
            });
        }); 
    }
    let queryB = function(){
        return new Promise(resolve=>{
            $.ajax({
                url:'url2',
                success:resolve,
            });
        }); 
    }
    let queryC = function(){
        return new Promise(resolve=>{
            $.ajax({
                url:'url3',
                success:resolve,
            });
        }); 
    }
    //先将queryA返回的实例赋给promise,每次执行then都会返回新的Prmise实例
    let promise = queryA();
    promise.then(result=>{
        console.log(1);
        return queryB();//将queryB的实例返回作为下一个的实例用于调用下一个then
    }).then(result=>{
        console.log(2);
        return queryC();
    }).then(result=>{
        console.log(3);
    });
  • 相关阅读:
    python 文件相关知识
    python字符串,列表,字符串,元组,集合的一些方法
    一些小技巧和破坏性的实验
    CentOs 系统启动流程相关
    入手内核的前篇之进程和计划任务
    外部中断的理解
    串口程序的理解
    USART1_IRQHandler 函数的理解
    STM32串口的理解
    中断NVIC优先级的理解
  • 原文地址:https://www.cnblogs.com/angle-xiu/p/11377659.html
Copyright © 2011-2022 走看看